求助
查看原帖
求助
359883
Grace25楼主2021/3/6 18:38

蒟蒻调不出来。。。

#include<iostream>
using namespace std;
const int INF=-1e7;
int f[1005][1005][3]={0},a[1005][1005],n,m;
int main(){
	cin >> n >> m;
	for(int i=1;i<=n;i++){
		for(int j=1;j<=m;j++){
			cin >> a[i][j];
			f[i][j][0] = f[i][j][1] = f[i][j][2] = INF;
			//初始化第一列和第一个格子 
			f[i][1][1] = f[i-1][1][1] + a[i][1];
			f[1][1][0] = f[1][1][1] = f[1][1][2] = a[1][1];				 
		}
	}
	for(int i=2;i<=m;i++){
		//初始化本列第一个 
	    f[1][i][0] = a[1][i];
	    //左边来&&上边来 
		for(int j=2;j<=n;j++){
			f[j][i][0] = max(f[j][i-1][0], max(f[j][i-1][1], f[j][i-1][2])) + a[j][i];
			f[j][i][1] = max(f[j-1][i][0], f[j-1][i][1]) + a[j][i];		 
		}
		for(int j=n-1;j>=1;j--){
            f[j][i][2] = max(f[j+1][i][0], f[j+1][i][2]) + a[j][i];			 
        } 
	}
	cout << max(f[n][m][0],f[n][m][1]);
	return 0;
}
2021/3/6 18:38
加载中...