四维动规 洛谷P1004方格取数

分析:这个题因为数据量非常小,可以直接用四维的DP数组

dp[i][j][k][l]表示第一个人走到位置(i,j),第二个人走到位置[k][l]时所取的数的最大和

状态转移方程可以轻松得出为:dp[i][j][k][l]=max(dp[i-1][j][k-1][l],max(dp[i-1][j][k][l-1],max(dp[i][j-1][k-1][l],dp[i][j-1][k][l-1])))+a[i][j]+a[k][l]

注意,当两个人走到同一个位置时,因为数取走后就没了,是需要减去同时走过的位置(这一点是本题的重点,在dp状态转移的过程中,会把所有两个人走的重复的点都遍历出来,所以在最后最大的结果里,只要有过两个人都走过的位置,就会减去一次重复位置处的数值)

 1 #include<bits/stdc++.h>
 2 using namespace std;
 3 typedef long long ll;
 4 const double pi=acos(-1);
 5 const int inf=1<<30;
 6 int a[10][10];
 7 int dp[10][10][10][10];
 8 int main(){
 9     int n;scanf("%d",&n);
10     int x,y,z;
11     while(scanf("%d%d%d",&x,&y,&z)){
12         if(!x&&!y&&!z) break;
13         a[x][y]=z;
14     }
15     for(int i=1;i<=n;i++){
16         for(int j=1;j<=n;j++){
17             for(int k=1;k<=n;k++){
18                 for(int l=1;l<=n;l++){
19         dp[i][j][k][l]=max(dp[i-1][j][k-1][l],max(dp[i-1][j][k][l-1],max(dp[i][j-1][k-1][l],dp[i][j-1][k][l-1])))+a[i][j]+a[k][l];
20             if(i==k&&j==l) dp[i][j][k][l]-=a[i][j];
21                 }
22             }
23         }
24     }
25     cout<<dp[n][n][n][n]<<endl;
26     return 0;
27 }
原文地址:https://www.cnblogs.com/qingjiuling/p/10197621.html