栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

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

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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

原题:添加链接描述

#include
#include

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<
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/699426.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号