社区讨论

我这动规哪错了,求大神指点

P1005[NOIP 2007 提高组] 矩阵取数游戏参与者 5已保存回复 6

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
6 条
当前快照
1 份
快照标识符
@mi5htoup
此快照首次捕获于
2025/11/19 12:19
4 个月前
此快照最后确认于
2025/11/19 12:19
4 个月前
查看原帖
CPP
#include<cstdio>
#include<cstring>
#include<iostream>
using namespace std;
int n,m,a[81][81];
long long now,f[85][85],ans,maxf;
inline void read(int &data){
    data=0;
    char ch=getchar();
    while(ch<'0'||ch>'9')ch=getchar();
    while(ch>='0'&&ch<='9')data=data*10+ch-'0',ch=getchar();
}
int main(){
    freopen("game.in","r",stdin);
    read(n),read(m);
    int i,j,k;
    for(i=1;i<=n;i++)for(j=1;j<=m;j++)read(a[i][j]);
    for(k=1;k<=n;k++){
        memset(f,0,sizeof(f));
        now=2;
        f[1][1]=2*a[k][1];
        f[1][m]=2*a[k][m];
        for(i=2;i<=m;i++){
            now*=2;
            for(j=1;j<=m;j++){
                if(i>=j){
                    maxf=max(f[i-1][j-1],f[i-1][m+j-i+1]);
                    if(maxf)f[i][j]=max(f[i][j],maxf+a[k][j]*now);
                }
                if(i+j>=m){
                    maxf=max(f[i-1][j+1],f[i-1][i+j-m-1]);
                    if(maxf)f[i][j]=max(f[i][j],maxf+a[k][j]*now);
                }
            }
        }
        maxf=0;
        for(i=1;i<=m;i++)maxf=max(maxf,f[m][i]);
        ans+=maxf;
        for(i=1;i<=m;i++)printf("%d ",f[m][i]);
        printf("\n");
    }
    printf("%d\n",ans);
    return 0;
}

回复

6 条回复,欢迎继续交流。

正在加载回复...