提交时间:2024-03-02 15:20:49
运行 ID: 134275
#include<bits/stdc++.h> using namespace std; int n,a[10001],s[10001],dp[10001][10001]; int main() { cin>>n; for(int i=1;i<=n;i++) for(int j=1;j<=n;j++) dp[i][j]=INT_MAX; for(int i=1;i<=n;i++) cin>>a[i],s[i]=s[i-1]+a[i],dp[i][i]=0; for(int len=2;len<=n;len++) for(int i=1;i+len-1<=n;i++) { int j=i+len-1; for(int k=i;k<j;k++) dp[i][j]=min(dp[i][j],dp[i][k]+dp[k+1][j]+s[j]-s[i-1]); } cout<<dp[1][n]; }