WA 80分代码球跳 WA#3(悬棺)
查看原帖
WA 80分代码球跳 WA#3(悬棺)
1419936
hydk2012楼主2025/7/30 16:44

rt,WA了第三个点

代码如下:

#include<bits/stdc++.h>
using namespace std;
int n,a[105],f[105][105],g[105][105];
char c[105];
int main()
{
    cin>>n;
    memset(g,0x3f3f3f3f,sizeof(g));
    memset(f,-1e9,sizeof(f));
    for(int i=1;i<=n;i++) cin>>c[i]>>a[i],a[i+n]=a[i],c[i+n]=c[i];
    for(int i=1;i<=2*n;i++) f[i][i]=g[i][i]=a[i];
    for(int len=1;len<=2*n;len++)
    {
        for(int i=1;i<=2*n;i++) 
        {
            int j=i+len-1;
            if(j<=2*n)
            {
                for(int k=i;k<j;k++)
                {
                    if(c[k+1]=='t')
                    {
                        f[i][j]=max(f[i][j],f[i][k]+f[k+1][j]);
                        g[i][j]=min(g[i][j],g[i][k]+g[k+1][j]);
                    }else
                    {
                        f[i][j]=max(f[i][j],max(f[i][k]*f[k+1][j],max(g[i][k]*g[k+1][j],max(f[i][k]*g[k+1][j],g[i][k]*f[k+1][j]))));
                        g[i][j]=min(g[i][j],min(f[i][k]*f[k+1][j],min(g[i][k]*g[k+1][j],min(f[i][k]*g[k+1][j],g[i][k]*f[k+1][j]))));
                    }
                }
            }
        }
    }
    int ans=-1e9;
    for(int i=1;i<=n;i++) ans=max(ans,f[i][i+n-1]);
    cout<<ans<<endl;
    for(int i=1;i<=n;i++)
    {
        if(ans==f[i][i+n-1]) cout<<i<<' ';
    }
    return 0;
}

球跳悬棺

2025/7/30 16:44
加载中...