AcWing 1027 方格取数 题解 (动态规划—DP—线性DP)

原题:添加链接描述
在这里插入图片描述

#include<iostream>
#include<algorithm>

using namespace std;

const int N = 150;

int n;
int w[N][N];
int f[N][N][N];//f[x][y][z]表示到达下标之和为x(其中一个点纵坐标为y,另一个点纵坐标为z)的两条路径上取得的最大的和 

int main()
{
	cin>>n;
	int a, b, c;
	while(cin>>a>>b>>c, a || b || c) w[a][b] = c;
	
	for(int k = 2; k <= n + n; k ++ ){//k表示目前状态两条路的两个点的下标之和 
		for(int i1 = 1; i1 <= n; i1 ++ ){//i1表示第一条路的纵坐标值 
			for(int i2 = 1; i2 <= n; i2 ++ ){//i2表示第二条路的纵坐标值 
				int j1 = k - i1, j2 = k - i2;//分别求出两条路的横坐标值 
				if(j1 >= 1 &&j1 <= n && j2 >= 1 && j2 <= n){//如果目前两条路所处的点都在网格内 
					int t = w[i1][j1];//t表示到达目前这个点f值需要的增量,默认先算第一条路径可以经过,如果重合则第二条路径不能经过 
					if(i1 != i2) t += w[i2][j2];//如果两条路的点没有重合,增量就记上第二条路上的数值
					int &x = f[k][i1][i2];
					//每次循环代表两条路中的一条向前移动一格,所以上一状态应该是k-1
					x = max(x, f[k - 1][i1 - 1][i2 - 1] + t);//表示新状态是由两条路都向下移动一格产生的
					x = max(x, f[k - 1][i1 - 1][i2] + t);//表示新状态是由第一条路向下,第二条路 向右移动产生的,因为第二条路向右,所以纵坐标不变,所以上一状态依然是i2
					x = max(x, f[k - 1][i1][i2 - 1] + t);//同理,由第一路右移,第二路下移产生
					x = max(x, f[k - 1][i1][i2] + t);//同理,由两条路都是右移产生 
				}
			}
		}
	}
	
	cout<<f[n + n][n][n]<<endl;
	return 0; 
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值