[Swust OJ 1084]--Mzx0821月赛系列之情书(双线程dp)

时间:2022-09-20 15:34:00

题目链接:http://acm.swust.edu.cn/problem/1084/

Time limit(ms): 1000        Memory limit(kb): 65535
 
Description

小时候,Mzx0821暗恋班上的一个妹子Zzx。

一次班上做活动,班上同学被安排坐成m行n列的矩阵,Mzx0821坐在坐标(x1,y1)的位置,Zzx坐在坐标(x2,y2)的位置。活动过程中,Mzx0821写了一张纸条想给Zzx,但是Mzx0821又不想班上其他人看到他写的内容,于是Mzx0821给班上每个人定义了一个保密程度值(就是这个人不偷看纸条内容的可能),每个人传递纸条只能给前后左右的人。

Mzx0821还考虑到万一Zzx给Mzx0821回纸条怎么办呢,为了保密,Mzx0821希望每个人最多传递一次纸条,就是说一个人在Mzx0821传给Zzx的时候帮了忙,就不能再帮Zzx传给Mzx0821,反之亦然。

Mzx0821希望找到这样两条路,使得来回两条路上的保密程度值的和最大,为了尽快传到,这两条路必须是Mzx0821到Zzx的之间的最短路。

Mzx0821智商实在捉急,于是向机智的学弟学妹们求助,你能帮助他找到正确的路线吗?

Input

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

为了简化问题我们假设Mzx0821坐在左上角,Zzx坐在右下角。

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

友情提示:Mzx0821坐标点的值和Zzx坐标点的值为0,坐标点的值<10000。

 
Output

输出共一行,包含一个整数,表示来回两条路上参与传递纸条的学生的保密程度之和的最大值。

 
Sample Input
3 3
0 3 9
2 8 5
5 7 0
Sample Output
34
 
输出换行请使用\r\n
 
 
解题思路:一个简单的双线程dp,直接写就是了,两个人同一个方向同时走,dp[i][j][x][y],代表第一个人走到(i,j),第二个人走到(x,y)的最大值
 

我们转化一下思想,题目中说由左上方到右下方来回,我们可以看作是从左上方找两条不相交的路径到右下方。这里我们可以好比是两个纸条同时从左上方向右下方传,只要保证在同一时刻两个纸条不在同一个人手里,那么我们就能保证两个字条的路径不相交.

  确定算法: DP(动态规划)
  状态:当前时刻的两个字条的坐标。

  状态转移方程式 :

  dp[i][j][x][y]= max{ dp[i-1][j][x-1][y],dp[i-1][j][x][y-1],dp[i][j-1][x-1][y],dp[i][j-1][x][y-1] }+mpt[i][j]+mpt[x][y]

  为了保证两个字条是同步传递的,所以方程式要加一个限定条件 ( i + j = x + y )☆
 
代码如下:
 #include<iostream>
#include<cstring>
#include<algorithm>
using namespace std; #define maxn 51
int m, n, mpt[maxn][maxn];
int dp[maxn][maxn][maxn][maxn];
//同一个方向同时走
//dp[i][j][x][y]代表当第一个人走到i,j且第二个人走到x,y时的最大值 int max(int x, int y, int z, int w){
return max(max(max(x, y), z), w);
}
int main()
{
while (cin >> m >> n){
memset(dp, , sizeof(dp));
for (int i = ; i <= m; i++)
for (int j = ; j <= n; j++)
cin >> mpt[i][j];
for (int i = ; i <= m; i++){
for (int j = ; j <= n; j++){
//第二个人走的路径在第一个人的下面,
for (int x = i + ; x <= m; x++){
int y = i + j - x;
if (y <= )continue;
dp[i][j][x][y] = max(dp[i - ][j][x - ][y], dp[i - ][j][x][y - ], dp[i][j - ][x][y - ], dp[i][j - ][x - ][y]) + mpt[i][j] + mpt[x][y];
}
}
}
//最后第一个人到终点的左边,第二个人到终点的右边
cout << dp[m - ][n][m][n - ] << "\r\n";
}
return ;
}

代码还可以优化成三维数组:

 #include<iostream>
#include<cstring>
#include<algorithm>
using namespace std; #define maxn 51
int m, n, mpt[maxn][maxn];
int dp[maxn][maxn][maxn];
//同一个方向同时走 int max(int x, int y, int z, int w){
return max(max(max(x, y), z), w);
}
int main()
{
while (cin >> m >> n){
memset(dp, , sizeof(dp));
for (int i = ; i <= m; i++)
for (int j = ; j <= n; j++)
cin >> mpt[i][j];
for (int i = ; i <= m; i++){
for (int j = ; j <= n; j++){
for (int x = ; x < i; x++){
dp[i][j][x] = max(dp[i - ][j][x - ], dp[i - ][j][x], dp[i][j - ][x - ], dp[i][j - ][x]) + mpt[i][j] + mpt[x][i + j - x];
}
}
}
//最后第一个人到终点的左边,第二个人到终点的右边
cout << dp[m][n - ][m - ] << "\r\n";
}
return ;
}

[Swust OJ 1084]--Mzx0821月赛系列之情书(双线程dp)的更多相关文章

  1. 51Nod 1084 矩阵取数问题 V2 双线程DP 滚动数组优化

    基准时间限制:2 秒 空间限制:131072 KB  一个M*N矩阵中有不同的正整数,经过这个格子,就能获得相应价值的奖励,先从左上走到右下,再从右下走到左上.第1遍时只能向下和向右走,第2遍时只能向 ...

  2. &lbrack;Swust OJ 404&rsqb;--最小代价树&lpar;动态规划&rpar;

    题目链接:http://acm.swust.edu.cn/problem/code/745255/ Time limit(ms): 1000 Memory limit(kb): 65535   Des ...

  3. &lbrack;Swust OJ 649&rsqb;--NBA Finals&lpar;dp&comma;后台略&lpar;hen&rpar;坑&rpar;

    题目链接:http://acm.swust.edu.cn/problem/649/ Time limit(ms): 1000 Memory limit(kb): 65535 Consider two ...

  4. SWUST OJ NBA Finals&lpar;0649&rpar;

    NBA Finals(0649) Time limit(ms): 1000 Memory limit(kb): 65535 Submission: 404 Accepted: 128   Descri ...

  5. C&num;多线程编程系列(二)- 线程基础

    目录 C#多线程编程系列(二)- 线程基础 1.1 简介 1.2 创建线程 1.3 暂停线程 1.4 线程等待 1.5 终止线程 1.6 检测线程状态 1.7 线程优先级 1.8 前台线程和后台线程 ...

  6. Java Thread系列(四)线程通信

    Java Thread系列(四)线程通信 一.传统通信 public static void main(String[] args) { //volatile实现两个线程间数据可见性 private ...

  7. Java Thread系列(三)线程安全

    Java Thread系列(三)线程安全 一.什么是线程安全 线程安全概念:当多个线程访问某一个类(对象或方法)时,这个类始终都能表现出正确的行为,那么这个类(对象或方法)就是线程安全的. 线程安全来 ...

  8. Java Thread系列(二)线程状态

    Java Thread系列(二)线程状态 一.线程的五种状态 新建状态(New):新创建了一个线程对象,尚未启动. 就绪状态(Runnable):也叫可运行状态.线程对象创建后,其他线程调用了该对象的 ...

  9. Java Thread系列(一)线程创建

    Java Thread系列(一)线程创建 Java 中创建线程主要有三种方式:继承 Thread.实现 Runnable 接口.使用 ExecutorService.Callable.Future 实 ...

随机推荐

  1. Struts2:类型转换器

    常规的String,int能自动转换,但是,有些类型不是这么简单,比如输入字符串,但需要Date.自定义类型,因此需要自定义类型转换类型转换器分全局和局部按惯例,局部的优先级高于全局 需求: 1.输入 ...

  2. 【BZOJ-4590】自动刷题机 二分 &plus; 判定

    4590: [Shoi2015]自动刷题机 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 156  Solved: 63[Submit][Status ...

  3. ACM&sol;ICPC 之 DP-基因相似度&lpar;POJ1080-ZOJ1027&rpar;

    题意:两端基因片段,各有明确的碱基序列,现有一个碱基匹配的相似度数组,设计程序使得该相似度最大. //POJ1080-ZOJ1027 //题解:将s1碱基和s2碱基看做等长,添加一个碱基为'-',即每 ...

  4. nc命令学习

    监测端口是否存在 nc -z 127.0.0.1 9100 扫描端口 nc -z -v 127.0.0.1 8000 9999 发送http nc www.baidu.com 80 GET / HTT ...

  5. 爬虫框架YayCrawler

    爬虫框架YayCrawler 各位好!从今天起,我将用几个篇幅的文字向大家介绍一下我的一个开源作品——YayCrawler,其在GitHub上的网址是:https://github.com/liush ...

  6. ajax jsonp 跨域请求

    $.ajax({ type:"get", url: "http://localhost/test/a.php", dataType: "jsonp&q ...

  7. 阿里云-对象储存OSS

    最近 需要搞一个阿里云的文件上传 手机端主要做了图片上传 pod安装:pod 'AliyunOSSiOS', '~> 2.5.2' 主要就是需要四个参数:accessKey secretKey  ...

  8. thinkphp 中的钩子应用

    1 创建钩子行为: 我们自己定义的标签位可以直接放在Think\Behaviors中,也可以放在应用目录中,比如说Home模块下,新建一个Behaviors的文件夹,在文件夹内新建 标签名+Behav ...

  9. day 10 - 1 函数进阶

    函数进阶 命名空间和作用域 命名空间 命名空间 有三种内置命名空间 —— python解释器 就是python解释器一启动就可以使用的名字存储在内置命名空间中 内置的名字在启动解释器的时候被加载进内存 ...

  10. meta总结

    做项目的时候发现正常的代码在360浏览器上样式都是乱的,翻阅资料才发现360是双核,分为极速模式和兼容模式,极速模式是用webkit内核,兼容模式是用trident内核(也就是IE内核),最后加了一行 ...