1 条题解

  • 1
    @ 2024-9-12 23:02:21

    参考答案:

    #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
    上传者