AC题解
2023-07-29 10:02:50
发布于:四川
18阅读
0回复
0点赞
#include<bits/stdc++.h>
using namespace std;
long long n,m;
long long a[1005][1005];
long long dp[1005][1005][3];
signed main(){
cin>>n>>m;
for(int i=1;i<=n;i++){
for(int j=1;j<=m;j++){
cin>>a[i][j];
dp[i][j][0]=dp[i][j][1]=dp[i][j][2]=-2147483647;
}
}
dp[1][1][0]=dp[1][1][1]=dp[1][1][2]=a[1][1];
for(int i=2;i<=n;i++){
dp[i][1][1]=dp[i-1][1][1]+a[i][1];
}
for(int i=2;i<=m;i++){
for(int j=1;j<=n;j++){
dp[j][i][0]=max(dp[j][i-1][0],max(dp[j][i-1][1],dp[j][i-1][2]))+a[j][i];
if(j>1) dp[j][i][1]=max(dp[j-1][i][0],dp[j-1][i][1])+a[j][i];
}
for(int j=n-1;j>=1;j--){
dp[j][i][2]=max(dp[j+1][i][0],dp[j+1][i][2])+a[j][i];
}
}
cout<<max(dp[n][m][0],max(dp[n][m][1],dp[n][m][2]));
return 0;
}
个人做法,仅供参考
这里空空如也
有帮助,赞一个