【洛谷】【动态规划(多维)】P1006 传纸条
【题目描述:】
小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题。一次素质拓展活动中,班上同学安排做成一个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共一行,包含一个整数,表示来回两条路上参与传递纸条的学生的好心程度之和的最大值。
输入样例#: 输出样例#:
输入输出样例
[算法分析:]
设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:]
//P1006传纸条
//688ms, 26.55MB
#include<iostream>
#include<cstdio>
using namespace std; const int MAXN = + ; int n, m;
int a[MAXN][MAXN];
int f[MAXN][MAXN][MAXN][MAXN]; inline int Max(int a, int b, int c, int d) { return max(max(max(a, b), c), d); } int main() {
scanf("%d%d", &n, &m);
for(int i=; i<=n; ++i)
for(int j=; j<=m; ++j)
scanf("%d", &a[i][j]);
for(int i=; i<=n; ++i)
for(int j=; j<=m; ++j)
for(int k=; k<=n; ++k)
for(int l=; l<=m; ++l) {
f[i][j][k][l] = Max(f[i-][j][k-][l], f[i-][j][k][l-],
f[i][j-][k-][l], f[i][j-][k][l-])+a[i][j]+a[k][l];
if(i==k && j==l) f[i][j][k][l] -= a[i][j];
}
printf("%d\n", f[n][m][n][m]);
}
未优化
//P1006传纸条
//16ms, 3MB
#include<iostream>
#include<cstdio>
using namespace std; const int MAXN = + ; int n, m;
int a[MAXN][MAXN];
int f[MAXN << ][MAXN][MAXN]; inline int Max(int a, int b, int c, int d) { return max(max(max(a, b), c), d); } int main() {
scanf("%d%d", &n, &m);
for(int i=; i<=n; ++i)
for(int j=; j<=m; ++j)
scanf("%d", &a[i][j]);
for(int i=; i<=n+m; ++i)
for(int j=; j<=n; ++j)
for(int k=; k<=n; ++k) {
int x1 = j, y1 = i - j,
x2 = k, y2 = i - k;
if(y1< || y2<) continue;
f[i][j][k] = Max(f[i-][j-][k], f[i-][j][k-],
f[i-][j][k], f[i-][j-][k-])+a[x1][y1]+a[x2][y2];
if(x1==x2 && y1==y2) f[i][j][k] -= a[x1][y1];
}
printf("%d\n", f[n+m][n][n]);
}
降维优化
【洛谷】【动态规划(多维)】P1006 传纸条的更多相关文章
- 棋盘DP三连——洛谷 P1004 方格取数 &&洛谷 P1006 传纸条 &&Codevs 2853 方格游戏
P1004 方格取数 题目描述 设有N $\times N$N×N的方格图(N $\le 9$)(N≤9),我们将其中的某些方格中填入正整数,而其他的方格中则放入数字00.如下图所示(见样例): A ...
- 洛谷 P1006 传纸条 题解
P1006 传纸条 题目描述 小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题.一次素质拓展活动中,班上同学安排做成一个m行n列的矩阵,而小渊和小轩被安排在矩阵对角线的两端,因此,他们就无法 ...
- P1006 传纸条(二维、三维dp)
P1006 传纸条 输入输出样例 输入 #1 复制 3 3 0 3 9 2 8 5 5 7 0 输出 #1 复制 34 说明/提示 [限制] 对于 30% 的数据,1≤m,n≤10: 对于 100% ...
- [Luogu P1006]传纸条 (网格DP)
题面 传送门:https://www.luogu.org/problemnew/show/P1006 Solution 挺显然但需要一定理解的网络(应该是那么叫吧)DP 首先有一个显然但重要的结论要发 ...
- 洛谷 P1006 传纸条 多维DP
传纸条详解: 蒟蒻最近接到了练习DP的通知,于是跑来试炼场看看:发现有点难(毕竟是蒟蒻吗)便去翻了翻题解,可怎么都看不懂.为什么呢?蒟蒻发现题解里都非常详细的讲了转移方程,讲了降维优化,但这题新颖之处 ...
- 【动态规划】洛谷P1006传纸条
题目描述: 小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题.一次素质拓展活动中,班上同学安排做成一个m行n列的矩阵,而小渊和小轩被安排在矩阵对角线的两端,因此,他们就无法直接交谈了.幸运的 ...
- P1006 传纸条-洛谷luogu-dp动态规划
题目描述 小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题.一次素质拓展活动中,班上同学安排做成一个mm行nn列的矩阵,而小渊和小轩被安排在矩阵对角线的两端,因此,他们就无法直接交谈了.幸运 ...
- 洛谷P1006 传纸条(多维DP)
小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题.一次素质拓展活动中,班上同学安排做成一个mm行nn列的矩阵,而小渊和小轩被安排在矩阵对角线的两端,因此,他们就无法直接交谈了.幸运的是,他们 ...
- 洛谷p1006 传纸条 三维解法
原题目如下 原地址https://www.luogu.com.cn/problem/P1006 题目描述 小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题.一次素质拓展活动中,班上同学安排做 ...
随机推荐
- oracle数据库逐步学习总结【基础一】
原创作品,转载请在文章开头显眼位置注明出处:https://www.cnblogs.com/sunshine5683/p/10059955.html 一.oracle的基本命令 1.连接命令 用法:c ...
- Hive 编程指南—笔记
1. 基础 1.1 Hive 解决问题的背景? 用户如何从一个现有的数据基础架构转移到 Hadoop 上,而这个基础架构是基于传统的关系数据库和 SQL 的? Hive 提供了一个被称为 HQL 的 ...
- java设计模式-----16、解释器模式
概念: Interpreter模式也叫解释器模式,是行为模式之一,它是一种特殊的设计模式,它建立一个解释器,对于特定的计算机程序设计语言,用来解释预先定义的文法.简单地说,Interpreter模式是 ...
- CSS3选择器:nth-child和:nth-of-type之间的差异——张鑫旭
一.深呼吸,直接内容 :nth-child和:nth-of-type都是CSS3中的伪类选择器,其作用近似却又不完全一样,对于不熟悉的人对其可能不是很区分,本文就将介绍两者的不同,以便于大家正确灵活使 ...
- 基于AlipayJSBridge封装的H5网页支付宝打赏、网站打赏、个人免签支付,支付宝转账打赏支付组件
之前公司要做个打赏用户的功能,网站查询一些资料之后把一些api封装之后提供了一个demo组件供大家下载:扫描下图二维码 功能: 支付宝H5 Js方案,调起应用内页面,自动设定转账金额和收款理由,用户付 ...
- [移动端WEB] 移动端input标签按钮为什么在苹果手机上还有一层白色?
移动端input标签按钮为什么在苹果手机上还有一层白色? 解决办法:其实蛮简单的,就加一个属性就好了 input { outline:0px ; -webkit-appearance: none; } ...
- 安装php扩展redis (windows环境)
首先十分感谢网络上支持开源分享的前辈们,资源真的太丰富了,虽然也有许多优秀的国外资源被墙了... 想要给php增加redis扩展第一步当然要知道自己使用的php版本以及一些配置.查看 phpinfo ...
- exception tomcat startup.bat 闪退
解决方案: startup.bat,右击->编辑,在文件头加入下面两行: SET JAVA_HOME=D:\Java\jdk1.7 (java jdk目录) SET TOMCAT_HOME=E: ...
- svn 同步资源库时忽略某些文件类型和文件夹
项目开发中,开发人员经常用SVN来管理代码,在和服务器同步时,每次都看到一堆.class,.log,target等文件,这样很不舒服. 解决方法: 打开:window-->preferences ...
- Acticity的生命周期和启动模式
典型情况下的生命周期 onCreate 表示创建Acticity,在这个方法中可以做一些初始化的操作,如加载界面布局资源,初始化Activity所需的数据 onRestart 表示重新启动Activi ...