来自: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]要特算(因为这属于"不合法状态")

  1. #include<iostream>
  2. #include<cassert>
  3. #include<cstdio>
  4. #include<cstring>
  5. #include<algorithm>
  6. #include<cmath>
  7. #include<string>
  8. #include<iterator>
  9. #include<cstdlib>
  10. #include<vector>
  11. #include<stack>
  12. #include<map>
  13. #include<set>
  14. using namespace std;
  15. #define rep(i,f,t) for(int i = (f),_end_=(t); i <= _end_; ++i)
  16. #define rep2(i,f,t) for(int i = (f),_end_=(t); i < _end_; ++i)
  17. #define dep(i,f,t) for(int i = (f),_end_=(t); i >= _end_; --i)
  18. #define dep2(i,f,t) for(int i = (f),_end_=(t); i > _end_; --i)
  19. #define clr(c, x) memset(c, x, sizeof(c) )
  20. typedef long long int64;
  21. const int INF = 0x5f5f5f5f;
  22. const double eps = 1e-8;
  23. //*****************************************************
  24. int d[100][55][55];
  25. int a[55][55];
  26. inline int max(int i,int j,int k,int l)
  27. {
  28. return max(max(i,j),max(k,l));
  29. }
  30. int main()
  31. {
  32. int n,m;
  33. scanf("%d%d",&n,&m);
  34. rep(i,1,n)rep(j,1,m)scanf("%d",&a[i][j]);
  35. rep(i,1,n+m-2)rep(x1,max(1,i+2-m),min(n,i+1))
  36. {
  37. int y1 = i - x1 + 2;
  38. rep(x2,max(x1+1,i+2-m), min(n,i+1))
  39. {
  40. int y2 = i - x2 + 2;
  41. d[i][x1][x2] = max(d[i-1][x1-1][x2-1], d[i-1][x1][x2-1],
  42. d[i-1][x1-1][x2],d[i-1][x1][x2])
  43. + a[x1][y1] + a[x2][y2];
  44. }
  45. }
  46. d[n+m-2][n][n] = d[n+m-3][n-1][n];
  47. cout<<d[n+m-2][n][n]<<endl;   //直接输出d[n+m-3][n-1][n]即可
  48. return 0;
  49. }

转载于:https://www.cnblogs.com/FuTaimeng/p/5588803.html

code1169 传纸条相关推荐

  1. NOIP2008传纸条[DP]

    题目描述 小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题.一次素质拓展活动中,班上同学安排做成一个m行n列的矩阵,而小渊和小轩被安排在矩阵对角线的两端,因此,他们就无法直接交谈了.幸运的是 ...

  2. 洛谷1006 传纸条

    题目描述 小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题.一次素质拓展活动中,班上同学安排做成一个m行n列的矩阵,而小渊和小轩被安排在矩阵对角线的两端,因此,他们就无法直接交谈了.幸运的是 ...

  3. nyoj 61 传纸条(一) (双线动归)nyoj 探寻宝藏

    传纸条(一) 时间限制:2000 ms  |  内存限制:65535 KB 难度:5 描述 小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题.一次素质拓展活动中,班上同学安排做成一个m行n列 ...

  4. NYOJ 61 传纸条(一)

    传纸条(一) 时间限制:2000 ms  |  内存限制:65535 KB 难度:5 描述 小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题.一次素质拓展活动中,班上同学安排做成一个m行n列 ...

  5. 洛谷P1006 传纸条(多维DP)

    小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题.一次素质拓展活动中,班上同学安排做成一个mm行nn列的矩阵,而小渊和小轩被安排在矩阵对角线的两端,因此,他们就无法直接交谈了.幸运的是,他们 ...

  6. SDNU 1194.传纸条(DP) 1032.机器人

    Description 小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题.一次素质拓展活动中,班上同学安排做成一个m行n列的矩阵,而小渊和小轩被安排在矩阵对角线的两端,因此,他们就无法直接交 ...

  7. 传纸条(洛谷-P1006)

    题目描述 小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题.一次素质拓展活动中,班上同学安排做成一个 m 行 n 列的矩阵,而小渊和小轩被安排在矩阵对角线的两端,因此,他们就无法直接交谈了. ...

  8. NYOJ 61:传纸条(一)(三维DP)

    传纸条(一) 时间限制:2000 ms  |  内存限制:65535 KB 难度:5 描述 小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题.一次素质拓展活动中,班上同学安排做成一个m行n列 ...

  9. java传纸条问题_小学生考试传纸条作弊,老师看到纸条内容,表示让人“着急”...

    现在的小学生真是太"调皮",当个小学老师整天和学生斗智斗勇,有时候真的被他们气的不行,可是有时候又被这群"熊孩子"的行为给逗乐,就拿考试这件事来说,给小学生监考 ...

最新文章

  1. apache 安装后默认主页无法打开_CAD教程:CAD软件打开图纸后钢筋符号无法读取的解决办法...
  2. # 从零開始搭建Hadoop2.7.1的分布式集群
  3. C语言按要求打印数组
  4. [Android]使用platform密钥来给apk文件签名的命令
  5. 容器学习 之 容器的概念(一)
  6. python引入自己写的文件_python引入自己写的Py文件
  7. [css] 怎么让div中的图片和文字同时上下居中?
  8. python中堆排序_Python实现堆排序的方法详解
  9. 算法:回溯十二 Word Search字符串匹配二维矩阵
  10. 【层级多标签文本分类】MSML-BERT 模型的层级多标签文本分类方法研究
  11. multisim扩大工作区_最详细最好的Multisim仿真教程要点
  12. js中进行字符串替换的方法
  13. 三个工具测试网络速度
  14. 2018年12月份计算机,桌面CPU天梯图2018年12月最新版 十二月台式电脑处理器排名...
  15. Unity 制作萌系live2d桌宠:屏幕自适应+交互
  16. 51JOB:根据HR处理简历的一般流程,简历投递后会有如下几种状态出现
  17. 一起talk C栗子吧(第一百九十三回:C语言实例--DIY less命令二 )
  18. 深入剖析优惠券核心架构设计
  19. 二、谷歌阻止苹果,谁来阻止谷歌
  20. 计算机名里的工作组和域都呈灰色无法修改了

热门文章

  1. VMware Workstation创建Windows 10(21H2)虚拟机
  2. pyOCD - 用于调试烧写 Cortex-M 芯片环境成功搭建
  3. 好消息与坏消息应该怎么说
  4. pp助手服务器开小差,无法连接game center服务器通信的处理方法
  5. ImportError: Loader FrozenImporter cannot handle module inspect ||python ide中正常运行,用pyinsta打包为exe文件报错
  6. 国际大会演讲ppt_如何在会议或活动中接受技术演讲
  7. STM32F103VET6流水灯
  8. ubuntu 安装监控系统软件工具netdata
  9. 无毒一身轻——21天改变体质
  10. VINS外参在线标定估计