code1169 传纸条
来自:http://www.cnblogs.com/DSChan/p/4862019.html
题目说找来回两条不相交路径,其实也可以等价为从(1,1)到(n,m)的两条不相交路径。
如果是只找一条,那又回到了最经典的 dp[i][j] = max(dp[i-1][j],dp[i][j-1]) + a[i][j]。
现在找两条,可以先把数组开到四维。
dp[x1][y1][x2][y2] = max{
dp[x1][y1-1][x2][y2-1],
dp[x1-1][y1][x2-1][y2],
dp[x1-1][y1][x2][y2-1],
dp[x1][y1-1][x2-1][y2]
}
+ a[x1][y1] + a[x2][y2]
要两条路径不能相交,也就是dp[x][y][x][y]属于非法状态,判断一下不能经过此状态即可。
最简单的方法是令x2>x1,因为dp[x1][y1][x2][y2]与dp[x2][y2][x1][y1]是等价的。
由于m和n最大到50,开四维的数组太大,当中有很多重复和浪费。
脑补一下,两张纸条同时传的话,同一时刻它们穿过的人数是相同的,根据这点可以进行降维。
令d[i][x1][x2]表示第i步两张纸条的x坐标分别是x1和x2,则y1=i-x1+2,y2=i-x2+2。
这样就可以得出dp方程
d[i][x1][x2] = max{ d[i-1][x1][x2], d[i-1][x1-1][x2], d[i-1][x1][x2-1], d[i-1][x1-1][x2-1] } + a[x1][i-x1+2] + a[x2][i-x2+2]
注意答案d[n+m-2][n][n]要特算(因为这属于"不合法状态")
- #include<iostream>
- #include<cassert>
- #include<cstdio>
- #include<cstring>
- #include<algorithm>
- #include<cmath>
- #include<string>
- #include<iterator>
- #include<cstdlib>
- #include<vector>
- #include<stack>
- #include<map>
- #include<set>
- using namespace std;
- #define rep(i,f,t) for(int i = (f),_end_=(t); i <= _end_; ++i)
- #define rep2(i,f,t) for(int i = (f),_end_=(t); i < _end_; ++i)
- #define dep(i,f,t) for(int i = (f),_end_=(t); i >= _end_; --i)
- #define dep2(i,f,t) for(int i = (f),_end_=(t); i > _end_; --i)
- #define clr(c, x) memset(c, x, sizeof(c) )
- typedef long long int64;
- const int INF = 0x5f5f5f5f;
- const double eps = 1e-8;
- //*****************************************************
- int d[100][55][55];
- int a[55][55];
- inline int max(int i,int j,int k,int l)
- {
- return max(max(i,j),max(k,l));
- }
- int main()
- {
- int n,m;
- scanf("%d%d",&n,&m);
- rep(i,1,n)rep(j,1,m)scanf("%d",&a[i][j]);
- rep(i,1,n+m-2)rep(x1,max(1,i+2-m),min(n,i+1))
- {
- int y1 = i - x1 + 2;
- rep(x2,max(x1+1,i+2-m), min(n,i+1))
- {
- int y2 = i - x2 + 2;
- d[i][x1][x2] = max(d[i-1][x1-1][x2-1], d[i-1][x1][x2-1],
- d[i-1][x1-1][x2],d[i-1][x1][x2])
- + a[x1][y1] + a[x2][y2];
- }
- }
- d[n+m-2][n][n] = d[n+m-3][n-1][n];
- cout<<d[n+m-2][n][n]<<endl; //直接输出d[n+m-3][n-1][n]即可
- return 0;
- }
code1169 传纸条的更多相关文章
- tyvj1011 传纸条
背景 NOIP2008复赛提高组第三题 描述 小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题.一次素质拓展活动中,班上同学安排做成一个m行n列的矩阵,而小渊和小轩被安排在矩阵对角线的两端, ...
- NOIP2008 传纸条
题目描述 小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题.一次素质拓展活动中,班上同学安排做成一个m行n列的矩阵,而小渊和小轩被安排在矩阵对角线的两端,因此,他们就无法直接交谈了.幸运的是 ...
- NOIP2008传纸条[DP]
题目描述 小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题.一次素质拓展活动中,班上同学安排做成一个m行n列的矩阵,而小渊和小轩被安排在矩阵对角线的两端,因此,他们就无法直接交谈了.幸运的是 ...
- NOIP2008 T3 传纸条 解题报告——S.B.S.
题目描述 小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题.一次素质拓展活动中,班上同学安排做成一个m行n列的矩阵,而小渊和小轩被安排在矩阵对角线的两端,因此,他们就无法直接交谈了.幸运的是 ...
- [NOIP2008] 提高组 洛谷P1006 传纸条
题目描述 小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题.一次素质拓展活动中,班上同学安排做成一个m行n列的矩阵,而小渊和小轩被安排在矩阵对角线的两端,因此,他们就无法直接交谈了.幸运的是 ...
- TYVJ 1011 NOIP 2008&&NOIP 2000 传纸条&&方格取数 Label:多线程dp
做题记录:2016-08-15 15:47:07 背景 NOIP2008复赛提高组第三题 描述 小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题.一次素质拓展活动中,班上同学安排做成一个m行 ...
- nyoj 61 传纸条
点击打开链接 传纸条(一) 时间限制:2000 ms | 内存限制:65535 KB 难度:5 描述 小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题.一次素质拓展活动中,班上同学安排做 ...
- P1011 传纸条//dp优化改进状态表示
P1011 传纸条 时间: 1000ms / 空间: 131072KiB / Java类名: Main 背景 NOIP2008复赛提高组第三题 描述 小渊和小轩是好朋友也是同班同学,他们在一起总有谈不 ...
- Wikioi 1169 传纸条
这道题是我人生第一道双线动规题,因此我觉得还是很有必要记录下来. 刚接触到这道题的时候我第一反应是单线的动规,可是下一秒我就觉得这样做可能会有问题,因为从左上角(以下简称A)到右下角(以下简称B)通过 ...
随机推荐
- jeecg中List页面的高级查询
1.普通的高级查询 <t:datagrid name="orderworthList" title="订单价值统计" actionUrl="or ...
- 解决win下无法ping通VM虚拟机CentOS系统的方法
事情描述:公司迁新址,电脑带过去之后,用xshell连接vm的centos系统老是连接失败,然后考虑到公司迁新址这个情况,我首先怀疑是ip的问题,然后在vm中执行ifconfig找到centos的ip ...
- [转]SVN 乱码问题
以下来自:http://godchenmeng.iteye.com/blog/797727 最近研究SVN.发现在创建补丁包的时候出现这种情况. 在文件顶部不论是什么代码都会变成乱码.在文件中如果有注 ...
- web项目中遇到的Maven包依赖冲突问题解决
在搭建web项目时,出现一个比较诡异的问题,任何JSP页面突然都不能够正常地显示,系统爆出HTTP:500(服务器内部错误)的页面 HTTP Status 500 - java.lang.No ...
- ALSA声卡笔记3--ASoC驱动重要结构体关系图
1.ASoC中重要的数据结构之间的关联方式 (1)Kernel-2.6.35-ASoC中各个结构的静态关系 ASoC把声卡实现为一个Platform Device,然后利用Platform_devic ...
- 【洛谷】P2880 [USACO07JAN]平衡的阵容Balanced Lineup(st表)
题目背景 题目描述: 每天,农夫 John 的N(1 <= N <= 50,000)头牛总是按同一序列排队. 有一天, John 决定让一些牛们玩一场飞盘比赛. 他准备找一群在对列中为置连 ...
- 16_Java正则和日期对象
01正则表达式的概念和作用 * A: 正则表达式的概念和作用 * a: 正则表达式的概述 * 正则表达式也是一个字符串,用来定义匹配规则,在Pattern类中有简单的规则定义. 可以结合字符串类的方法 ...
- array,vector对象 数组越界检测
- [Z]CiteSeer统计的计算机领域的期刊和会议的影响因子
稍微有点早,04年的,但很全 http://emuch.net/html/200510/128286.html 另附一个不明来路的排名:http://www.wi2.uni-erlangen.de/_ ...
- 大数据,物联网(Internet of Things),万物互联网(Internet of Everything),云计算,雾计算,边缘计算(Edge Computing) 的区别和联系
大数据是一种规模大到在获取.存储.管理.分析方面大大超出了传统数据库软件工具能力范围的数据集合,具有海量的数据规模.快速的数据流转.多样的数据类型,高价值性和准确性五大特征,即5V(Volume, V ...