[洛谷P1006] 传纸条
双线程DP的常识;DP的阶段问题;多阶段决策问题
传送门:$>here<$
题意
n*m的矩阵里,从左上角走到右下角(只能往右或往下),再从右下角走回左上角(只能往左或往上)。其中不能重复经过一个点。问最长路。
数据范围:$n,m \leq 50$
Solution
问题的转化
和上一题有点类似。把往回走的那一条路径看做是从左上到右下的另一条路径。问题转化为求从左上到右下,两条不相交的路径,要求总长最长。
如何转移保证不重复走?
容易想到dp[i][j][a][b]表示第一个人走到(i,j),第二个走到(a,b)的最长路。
于是很快就想到了dp[i][j][a][b]=max{dp[i][j][a][b-1]...}这种转移方法了。这种转移方法的实质是令一个人不动,另一个人走一步。但是很遗憾,这种方法是不能保证不重复的。举一个反例,dp[2][2][1][2]这一个状态,如果从dp[2][2][1][1]转移而来,那么就有可能是(1,1)->(1,2)->(2,2)和(1,1)->(1,2)的叠加。可见(1,2)走了两次。
DP的阶段性
对于这种双线程的DP,往往要两个线程同时考虑。如果同时考虑的话,那么两人某一时刻的位置一定在同一条对角线上(仔细思考)。那么走到同一个点的意思就是两人相遇。那么只要将两人相遇的状态设为无限小,那么就自然避开了。
有了这一点性质(每一对角线作为阶段),DP是可以继续优化的。例如直接用dp[k][i][j]来表示状态。其中k表示第几条对角线,i,j是两人的横坐标。更进一步,由于多阶段DP的某一状态只取决于上一状态,还可以用滚动数组优化。那么就变成二维DP了。
透过题解看本质
双线程与阶段
从这道题里我发现双线程的情况往往同时考虑,并且以每一步决策作为一个阶段。和上一题不同,为什么上一题可以分开转移呢?是因为上一题以往前覆盖一个点作为一个阶段,两人走的步数可以是不一样的。而这道题两人的步数是一样,如果按照不一样考虑就会出现跟随的问题。
多阶段DP问题
将一个DAG分做一个多阶段的DAG往往更清晰。关键是要从题目中看出作为阶段的量。
my code
/*By DennyQi 2019*/
#include <cstdio>
#include <queue>
#include <cstring>
#include <algorithm>
using namespace std;
typedef long long ll;
;
;
const int INF = 0x3f3f3f3f;
inline int Max(const int a, const int b){ return (a > b) ? a : b; }
inline int Min(const int a, const int b){ return (a < b) ? a : b; }
inline int read(){
; ; register char c = getchar();
'); c = getchar());
, c = getchar();
) + (x<<) + c - '; return x * w;
}
int n,m;
][][][],s[][];
int main(){
n = read(), m = read();
; i <= n; ++i){
; j <= m; ++j){
s[i][j] = read();
}
}
memset(dp,-0x3f,sizeof(dp));
dp[][][][] = ;
; i <= n; ++i){
; j <= m; ++j){
; a <= n; ++a){
; b <= m; ++b){
if(i==a && j==b){
continue;
}
dp[i][j][a][b] = max(max(dp[i-][j][a-][b],dp[i-][j][a][b-]),max(dp[i][j-][a-][b],dp[i][j-][a][b-]))+s[i][j]+s[a][b];
}
}
}
}
printf(][m][n][m-]);
;
}
[洛谷P1006] 传纸条的更多相关文章
- 棋盘DP三连——洛谷 P1004 方格取数 &&洛谷 P1006 传纸条 &&Codevs 2853 方格游戏
P1004 方格取数 题目描述 设有N $\times N$N×N的方格图(N $\le 9$)(N≤9),我们将其中的某些方格中填入正整数,而其他的方格中则放入数字00.如下图所示(见样例): A ...
- 洛谷 P1006 传纸条 题解
P1006 传纸条 题目描述 小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题.一次素质拓展活动中,班上同学安排做成一个m行n列的矩阵,而小渊和小轩被安排在矩阵对角线的两端,因此,他们就无法 ...
- 洛谷p1006 传纸条 三维解法
原题目如下 原地址https://www.luogu.com.cn/problem/P1006 题目描述 小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题.一次素质拓展活动中,班上同学安排做 ...
- [NOIP2008] 提高组 洛谷P1006 传纸条
题目描述 小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题.一次素质拓展活动中,班上同学安排做成一个m行n列的矩阵,而小渊和小轩被安排在矩阵对角线的两端,因此,他们就无法直接交谈了.幸运的是 ...
- 【动态规划】洛谷P1006传纸条
题目描述: 小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题.一次素质拓展活动中,班上同学安排做成一个m行n列的矩阵,而小渊和小轩被安排在矩阵对角线的两端,因此,他们就无法直接交谈了.幸运的 ...
- 洛谷 P1006 传纸条 多维DP
传纸条详解: 蒟蒻最近接到了练习DP的通知,于是跑来试炼场看看:发现有点难(毕竟是蒟蒻吗)便去翻了翻题解,可怎么都看不懂.为什么呢?蒟蒻发现题解里都非常详细的讲了转移方程,讲了降维优化,但这题新颖之处 ...
- Codevs 1169 == 洛谷 P1006 传纸条
---恢复内容开始--- 1169 传纸条 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description 小渊和小轩是好朋友也是同班同学,他 ...
- 洛谷 P1006 传纸条
题目描述 小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题.一次素质拓展活动中,班上同学安排做成一个m行n列的矩阵,而小渊和小轩被安排在矩阵对角线的两端,因此,他们就无法直接交谈了.幸运的是 ...
- 洛谷P1006 传纸条 (棋盘dp)
好气,在洛谷上交就过了,在caioj上交就只有40分 之前在51nod做过这道题了. https://blog.csdn.net/qq_34416123/article/details/8180902 ...
- 洛谷P1006 传纸条(多维DP)
小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题.一次素质拓展活动中,班上同学安排做成一个mm行nn列的矩阵,而小渊和小轩被安排在矩阵对角线的两端,因此,他们就无法直接交谈了.幸运的是,他们 ...
随机推荐
- VS code 设置中文后也显示英文的问题
按f1 搜索 Configore Display Language 设置 zh-cn 关闭软件重启. 如果重启菜单等还是英文的,在商店查看已安装的插件,把中文插件重新安装一遍,然后重启软件.
- vue鼠标悬停事件
v-bind:title="message" <!DOCTYPE html> <html lang="en"> <head> ...
- 学习day02
day021.结构标记 ***** 做布局 1.<header>元素 <header></header> ==> <div id="heade ...
- 前端开发中使用mac自带apache服务
场景 前端开发中,总是会有这样的需求,就是快速的写一个脚本,或者一个简单的demo页面.这时,我们需要马上可以启动一个web服务,来支持开发. 我们可以安装一个全局的cli工具,通过node服务来满足 ...
- web服务器负载均衡与集群基本概念一
Web集群是由多个同时运行同一个web应用的服务器组成,在外界看来就像一个服务器一样,这多台服务器共同来为客户提供更高性能的服务.集群更标准的定义是:一组相互独立的服务器在网络中表现为单一的系统,并以 ...
- win10 64位IIS链接32位ACCESS数据库
window10中IIS运行.asp文件链接数据库时出现错误,显示“An error occurred on the server when processing the URL. Please co ...
- 持续集成之 Spring Boot 实战篇
本文作者: CODING 用户 - 何健 这次实战篇,我们借助「CODING 持续集成」,实现一个简单的 Spring Boot 项目从编码到最后部署的完整过程.本教程还有 B 站视频版,帮助读者更好 ...
- 斐波那契数列(C#)
斐波那契数,亦称之为斐波那契数列(意大利语: Successione di Fibonacci),又称黄金分割数列.费波那西数列.费波拿契数.费氏数列,指的是这样一个数列:1.1.2.3.5.8.13 ...
- git在开发中的一些使用
git 获取远程分支: 步骤如下: 首先:git fetch --all 其次:git checkout 分支名 例如:git checkout pmt-45424-TOUCHWEB 这样就可以获取到 ...
- python defaultdict模块
from collections import defaultdict '''默认值字典'''d = defaultdict(lambda :123)print(d)print(type(d))pri ...