1 条题解
-
1
参考答案:
#include<iostream> #include<cstring> using namespace std; const int N=410; int f[N][N],g[N][N]; int a[N],s[N]; int n; int main() { cin>>n; for(int i=1;i<=n;++i) { cin>>a[i]; a[i+n]=a[i]; } for(int i=1;i<=2*n;++i) s[i]+=s[i-1]+a[i]; for(int len=2;len<=n;++len) { for(int i=1;i<=2*n-len+1;++i) { int l=i,r=i+len-1; f[l][r]=0x3f3f3f3f; g[l][r]=-0x3f3f3f3f; for(int k=l;k<r;++k) { f[l][r]=min(f[l][r],f[l][k]+f[k+1][r]+s[r]-s[l-1]); g[l][r]=max(g[l][r],g[l][k]+g[k+1][r]+s[r]-s[l-1]); } } } int minx=1e9,maxx=-1e9; for(int i=1;i<=n;++i) { int l=i,r=i+n-1; minx=min(minx,f[i][r]); maxx=max(maxx,g[i][r]); } cout<<minx<<endl; cout<<maxx<<endl; return 0; }
- 1
信息
- ID
- 5359
- 时间
- 1000ms
- 内存
- 256MiB
- 难度
- 10
- 标签
- 递交数
- 2
- 已通过
- 1
- 上传者