【题目描述:】

小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题。一次素质拓展活动中,班上同学安排做成一个m行n列的矩阵,而小渊和小轩被安排在矩阵对角线的两端,因此,他们就无法直接交谈了。幸运的是,他们可以通过传纸条来进行交流。纸条要经由许多同学传到对方手里,小渊坐在矩阵的左上角,坐标(1,1),小轩坐在矩阵的右下角,坐标(m,n)。从小渊传到小轩的纸条只可以向下或者向右传递,从小轩传给小渊的纸条只可以向上或者向左传递。

在活动进行中,小渊希望给小轩传递一张纸条,同时希望小轩给他回复。班里每个同学都可以帮他们传递,但只会帮他们一次,也就是说如果此人在小渊递给小轩纸条的时候帮忙,那么在小轩递给小渊的时候就不会再帮忙。反之亦然。

还有一件事情需要注意,全班每个同学愿意帮忙的好感度有高有低(注意:小渊和小轩的好心程度没有定义,输入时用0表示),可以用一个0-100的自然数来表示,数越大表示越好心。小渊和小轩希望尽可能找好心程度高的同学来帮忙传纸条,即找到来回两条传递路径,使得这两条路径上同学的好心程度只和最大。现在,请你帮助小渊和小轩找到这样的两条路径。

【输入格式:】

输入文件message.in的第一行有2个用空格隔开的整数m和n,表示班里有m行n列(1<=m,n<=50)。

接下来的m行是一个m*n的矩阵,矩阵中第i行j列的整数表示坐在第i行j列的学生的好心程度。每行的n个整数之间用空格隔开。

【输出格式:】

输出文件message.out共一行,包含一个整数,表示来回两条路上参与传递纸条的学生的好心程度之和的最大值。

  1. 输入样例#:
  2.  
  3. 输出样例#:

输入输出样例

[算法分析:]

设f[i][j][k][l]表示小渊走到点(i, j)小轩走到点(k, l)时的最大好心度之和

a[i][j]表示点(i, j)上的同学的好心度

则状态转移方程为:

  f[i][j][k][l] = max{f[i - 1][j][k - 1][l], f[i - 1][j][k][l - 1], f[i][j - 1][k - 1][l], f[i][j - 1][k][l - 1]} + a[i][j] + a[k][l]

特判如果两个点在一个点上就只加一个a[i][j].

时间复杂度为O(n2 * m2)(可以粗略地看成O(n4))

关于优化:

仔细思考后发现可以把四维压到三维

此时f[i][j][k]表示小渊和小轩总共走了i步时小渊在第j行,小轩在第k行

则此时小渊的坐标为(j, i - j),小轩的坐标为(k, i - k)

状态转移方程为:

  f[i][j][k] = max{f[i - 1][j - 1][k], f[i - 1][j][k - 1], f[i - 1][j][k], f[i - 1][j - 1][k - 1]} + a[j][i - j] + a[k][i - k]

注意此时f数组的第一维要开原来两倍的空间,还要判断列数合不合法.

时间复杂度O((n + m) * n2)(可以粗略地看成O(n3))

[Code:]

  1. //P1006传纸条
  2. //688ms, 26.55MB
  3. #include<iostream>
  4. #include<cstdio>
  5. using namespace std;
  6.  
  7. const int MAXN = + ;
  8.  
  9. int n, m;
  10. int a[MAXN][MAXN];
  11. int f[MAXN][MAXN][MAXN][MAXN];
  12.  
  13. inline int Max(int a, int b, int c, int d) { return max(max(max(a, b), c), d); }
  14.  
  15. int main() {
  16. scanf("%d%d", &n, &m);
  17. for(int i=; i<=n; ++i)
  18. for(int j=; j<=m; ++j)
  19. scanf("%d", &a[i][j]);
  20. for(int i=; i<=n; ++i)
  21. for(int j=; j<=m; ++j)
  22. for(int k=; k<=n; ++k)
  23. for(int l=; l<=m; ++l) {
  24. f[i][j][k][l] = Max(f[i-][j][k-][l], f[i-][j][k][l-],
  25. f[i][j-][k-][l], f[i][j-][k][l-])+a[i][j]+a[k][l];
  26. if(i==k && j==l) f[i][j][k][l] -= a[i][j];
  27. }
  28. printf("%d\n", f[n][m][n][m]);
  29. }

未优化

  1. //P1006传纸条
  2. //16ms, 3MB
  3. #include<iostream>
  4. #include<cstdio>
  5. using namespace std;
  6.  
  7. const int MAXN = + ;
  8.  
  9. int n, m;
  10. int a[MAXN][MAXN];
  11. int f[MAXN << ][MAXN][MAXN];
  12.  
  13. inline int Max(int a, int b, int c, int d) { return max(max(max(a, b), c), d); }
  14.  
  15. int main() {
  16. scanf("%d%d", &n, &m);
  17. for(int i=; i<=n; ++i)
  18. for(int j=; j<=m; ++j)
  19. scanf("%d", &a[i][j]);
  20. for(int i=; i<=n+m; ++i)
  21. for(int j=; j<=n; ++j)
  22. for(int k=; k<=n; ++k) {
  23. int x1 = j, y1 = i - j,
  24. x2 = k, y2 = i - k;
  25. if(y1< || y2<) continue;
  26. f[i][j][k] = Max(f[i-][j-][k], f[i-][j][k-],
  27. f[i-][j][k], f[i-][j-][k-])+a[x1][y1]+a[x2][y2];
  28. if(x1==x2 && y1==y2) f[i][j][k] -= a[x1][y1];
  29. }
  30. printf("%d\n", f[n+m][n][n]);
  31. }

降维优化

【洛谷】【动态规划(多维)】P1006 传纸条的更多相关文章

  1. 棋盘DP三连——洛谷 P1004 方格取数 &&洛谷 P1006 传纸条 &&Codevs 2853 方格游戏

    P1004 方格取数 题目描述 设有N $\times N$N×N的方格图(N $\le 9$)(N≤9),我们将其中的某些方格中填入正整数,而其他的方格中则放入数字00.如下图所示(见样例): A ...

  2. 洛谷 P1006 传纸条 题解

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

  3. P1006 传纸条(二维、三维dp)

    P1006 传纸条 输入输出样例 输入 #1 复制 3 3 0 3 9 2 8 5 5 7 0 输出 #1 复制 34 说明/提示 [限制] 对于 30% 的数据,1≤m,n≤10: 对于 100% ...

  4. [Luogu P1006]传纸条 (网格DP)

    题面 传送门:https://www.luogu.org/problemnew/show/P1006 Solution 挺显然但需要一定理解的网络(应该是那么叫吧)DP 首先有一个显然但重要的结论要发 ...

  5. 洛谷 P1006 传纸条 多维DP

    传纸条详解: 蒟蒻最近接到了练习DP的通知,于是跑来试炼场看看:发现有点难(毕竟是蒟蒻吗)便去翻了翻题解,可怎么都看不懂.为什么呢?蒟蒻发现题解里都非常详细的讲了转移方程,讲了降维优化,但这题新颖之处 ...

  6. 【动态规划】洛谷P1006传纸条

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

  7. P1006 传纸条-洛谷luogu-dp动态规划

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

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

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

  9. 洛谷p1006 传纸条 三维解法

    原题目如下 原地址https://www.luogu.com.cn/problem/P1006 题目描述 小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题.一次素质拓展活动中,班上同学安排做 ...

随机推荐

  1. [PHP] 超全局变量$_FILES上传文件

    1.$_FILES --超全局变量,HTTP 文件上传变量 通过 HTTP POST 方式上传到当前脚本的项目的数组,PHP 能够接受任何来自符合 RFC-1867 标准的浏览器上传的文件, 上传的过 ...

  2. 1.1 JAVA装箱和拆箱以及Java Number & Math&Character 类

    JAVA装箱和拆箱 从Java SE5开始就提供了自动装箱的特性,如果要生成一个数值为10的Integer对象,只需要这样就可以了.原文链接: http://www.cnblogs.com/dolph ...

  3. [js常用]百度将文字转化为语音实例

    嗷嗷方便的文字转语音,不过用的时候记得到百度语音上申请key,免费的.之前在网络上看到有人写了一部分,自己丰富下,以后用也方便 <!DOCTYPE html PUBLIC "-//W3 ...

  4. UVAlive6807 Túnel de Rata (最小生成树)

    题意 题目链接 Sol 神仙题Orz 我们考虑选的边的补集,可以很惊奇的发现,这个补集中的边恰好是原图中的一颗生成树: 并且答案就是所有边权的和减去这个边集中的边的权值: 于是我们只需要求最大生成树就 ...

  5. 【MUI框架】学习笔记整理 Day 1

    MUI 框架之 [原生UI] (1)accordion(折叠面板) 由二级列表演化而来 <ul class="mui-table-view"> 2 <li cla ...

  6. Linux之FineBI集群部署

    在企业应用中,通常单个计算机的配置是有限的,而企业应用又是高并发的需求,这个时候会通过计算机集群的方式来提高并发数,从而提高整体应用服务的性能.集群是将多台计算机作为一个整体来提供相关应用的服务.Fi ...

  7. 编译器错误消息: CS0016: 未能写入输出文件"c:\Windows\Microsoft.NET\Framework

    解决办法: 原因是由于系统目录下的Temp目录无相应的权限所致,具体操作如下: 来到C:/Windows目录,修改temp文件夹的属性. 在安全页设置IIS-IUSRS的权限,赋予修改.读取.写入等权 ...

  8. Pig limit用法举例

    lmt = limit data 10;   只获取指定条数的数据,不能保证每次得到的结果一致,先执行order再limit可以保证一致.   输入数据全部载入.   会触发reduce阶段   a ...

  9. Webservice和EJB

    WebService Web Service也叫XML Web Service WebService是一种可以接收从Internet或者Intranet上的其它系统中传递过来的请求,轻量级的独立的通讯 ...

  10. python及pandas,numpy等知识点技巧点学习笔记

    python和java,.net,php web平台交互最好使用web通信方式,不要使用Jypython,IronPython,这样的好处是能够保持程序模块化,解耦性好 python允许使用'''.. ...