Codeforces Round #131 (Div. 2) E. Relay Race dp
题目链接:
http://codeforces.com/problemset/problem/214/E
Relay Race
time limit per test4 secondsmemory limit per test256 megabytes
#### 问题描述
> Furik and Rubik take part in a relay race. The race will be set up on a large square with the side of n meters. The given square is split into n × n cells (represented as unit squares), each cell has some number.
>
> At the beginning of the race Furik stands in a cell with coordinates (1, 1), and Rubik stands in a cell with coordinates (n, n). Right after the start Furik runs towards Rubik, besides, if Furik stands at a cell with coordinates (i, j), then he can move to cell (i + 1, j) or (i, j + 1). After Furik reaches Rubik, Rubik starts running from cell with coordinates (n, n) to cell with coordinates (1, 1). If Rubik stands in cell (i, j), then he can move to cell (i - 1, j) or (i, j - 1). Neither Furik, nor Rubik are allowed to go beyond the boundaries of the field; if a player goes beyond the boundaries, he will be disqualified.
>
> To win the race, Furik and Rubik must earn as many points as possible. The number of points is the sum of numbers from the cells Furik and Rubik visited. Each cell counts only once in the sum.
>
> Print the maximum number of points Furik and Rubik can earn on the relay race.
#### 输入
> The first line contains a single integer (1 ≤ n ≤ 300). The next n lines contain n integers each: the j-th number on the i-th line ai, j ( - 1000 ≤ ai, j ≤ 1000) is the number written in the cell with coordinates (i, j).
#### 输出
> On a single line print a single number — the answer to the problem.
#### 样例
> **sample input**
> 3
> 25 16 25
> 12 18 19
> 11 13 8
>
> **sample output**
> 136
题意
给你一个n*n的网格,每个格子有一个数字,求从(1,1)到(n,n)的两条路线,使得经过的数字的和最大。(如果一个人经过了一个格子,下一个人再经过就只能得到0)
题解
看上去要开4维,其实开3维就能做的dp。
dp[k][i1][i2]表示两个人从(0,0)点出发走到第k个从对角线上(i1+j1k&&i2+j2k)一个在(i1,k-i1),一个在(i2,k-i2)上的最大值。
代码
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
typedef int LL;
const int maxn = 301;
const int INF = 0x3f3f3f3f;
int arr[maxn][maxn];
int n;
LL dp[maxn*2][maxn][maxn];
LL dfs(int k,int i1, int i2) {
	if (dp[k][i1][i2]>-INF) return dp[k][i1][i2];
	LL &res = dp[k][i1][i2];
	int j1 = k - i1, j2 = k - i2;
	//上上
	if (i1 - 1 >= 0 && i2 - 1 >= 0) res = max(res, dfs(k - 1, i1 - 1, i2 - 1));
	//上左
	if (i1 - 1 >= 0 && j2 - 1 >= 0) res = max(res, dfs(k - 1, i1 - 1, i2));
	//左上
	if (j1 - 1 >= 0 && i2 - 1 >= 0) res = max(res, dfs(k - 1, i1, i2 - 1));
	//左左
	if (j1 - 1 >= 0 && j2 - 1 >= 0) res = max(res, dfs(k - 1, i1, i2));
	//(i1 == i2 ? 0 : arr[i2][j2])一定要加括号!可能是res+影响的吧,不加会wa很惨orz
	res += arr[i1][j1] + (i1 == i2 ? 0 : arr[i2][j2]);
}
int main() {
	for (int i = 0; i < maxn * 2; i++) {
		for (int j = 0; j < maxn; j++) {
			for (int k = 0; k < maxn; k++) {
				dp[i][j][k] = -INF;
			}
		}
	}
	scanf("%d", &n);
	for (int i = 0; i < n; i++) {
		for (int j = 0; j < n; j++) {
			scanf("%d", &arr[i][j]);
		}
	}
	dp[0][0][0] = arr[0][0];
	LL ans=dfs(2*n-2,n - 1, n - 1);
	printf("%d\n", ans);
	return 0;
}Codeforces Round #131 (Div. 2) E. Relay Race dp的更多相关文章
- Codeforces Round #131 (Div. 2)
		A. System of Equations \(a\)的范围在\(\sqrt n\)内,所以暴力枚举即可. B. Hometask 需要被2.5整除,所以末位必然为0,如果0没有出现,则直接返回-1 ... 
- Codeforces Round #174 (Div. 1) B. Cow Program(dp + 记忆化)
		题目链接:http://codeforces.com/contest/283/problem/B 思路: dp[now][flag]表示现在在位置now,flag表示是接下来要做的步骤,然后根据题意记 ... 
- Codeforces Round #346 (Div. 2) D Bicycle Race
		D. Bicycle Race 题目链接http://codeforces.com/contest/659/problem/D Description Maria participates in a ... 
- Codeforces Round #346 (Div. 2) D. Bicycle Race 叉积
		D. Bicycle Race 题目连接: http://www.codeforces.com/contest/659/problem/D Description Maria participates ... 
- Codeforces Round #131 (Div. 1) B. Numbers dp
		题目链接: http://codeforces.com/problemset/problem/213/B B. Numbers time limit per test 2 secondsmemory ... 
- Codeforces Round #131 (Div. 2) B. Hometask dp
		题目链接: http://codeforces.com/problemset/problem/214/B Hometask time limit per test:2 secondsmemory li ... 
- Codeforces Round #131 (Div. 2) : B
		首先能被2,5整除的数结尾必须是0: 如果没有0肯定不行: 然后判断他们的和ans%3: 如果==0,直接从大到小输出就行: 如果==1,要么删除它们之间最小的那个%3==1的,要么删除两个小的并且% ... 
- Codeforces Round #131 (Div. 1) A - Game
		A. Game time limit per test 1 second memory limit per test 256 megabytes input standard input output ... 
- Codeforces Round #338 (Div. 2) C. Running Track dp
		C. Running Track 题目连接: http://www.codeforces.com/contest/615/problem/C Description A boy named Ayrat ... 
随机推荐
- 设置Safari浏览器在标签栏上打开新窗口,而不是弹出一个新窗口
			打开Safari浏览器的偏好设置,如图: 打开“标签”一项,如上图.在“在标签(而不是窗口)中打开页面:”中设置. 
- 导航控制器(UINavigationController)
			一.导航控制器基础 1.导航控制器的组成 i.中间视图 ii.导航栏 iii.工具栏 2.配置一个导航界面 a.配置一个导航界面最重要的部分就是配置被包含的视图控制器. b.当它所属的视图控制器在导航 ... 
- AWS学习之EC2
			1.AWS简介 AWS(Amazon Web Services )提供了一整套云计算服务,让您能够构建复杂.可扩展的应用程序.如今,成千上万各种规模的客户都在使用这些云计算服务,它们涉及各个行业,包括 ... 
- iostat命令简单说说
			tps: 每秒钟发送到的I/O请求数. Blk_read /s: 每秒读取的block数 Blk_wrtn/s: 每秒写入的block数 Blk_read: 读入的block总数 Blk_wrtn: ... 
- 使用sqoop将mysql数据导入到hadoop
			hadoop的安装配置这里就不讲了. Sqoop的安装也很简单. 完成sqoop的安装后,可以这样测试是否可以连接到mysql(注意:mysql的jar包要放到 SQOOP_HOME/lib 下): ... 
- 关于编程语言(转/收藏)-原文作者:韩天峰(Rango)
			原文在这里:http://rango.swoole.com/archives/405 容易让人记住的文章,要么引起共鸣,要么催人奋进.一句话,你已走过,而我也在路上. 最近群里很多朋友询问我是如何学习 ... 
- FileInputStream利用缓冲数组读取数据
			package cd.itcast.fileinputstream; import java.io.File; import java.io.FileInputStream; import java. ... 
- markdown文档编写
			(这里面的符号都是英文的:回车是需要:空格 空格 回车) # markdown练习---1.引入图片(1和4只差!)  题解
			[问题描述] 现给定n个闭区间[ai,bi],1<=i<=n.这些区间的并可以表示为一些不相交的闭区间的并.你的任务就是在这些表示方式中找出包含最少区间的方案.你的输出应该按照区间的升序排 ... 
- N进制数组转换成正整数
			给定一个任意长度的数组,其中的元素按照一定的进制(N进制)来转换成正整数 //把数组中的元素按照N进制转换成为正整数 #include <stdio.h> #include <std ... 
