洛谷 P1004 方格取数 【多进程dp】
题目链接:https://www.luogu.org/problemnew/show/P1004
题目描述
设有N*N的方格图(N<=9),我们将其中的某些方格中填入正整数,而其他的方格中则放
人数字0。如下图所示(见样例):
A
0 0 0 0 0 0 0 0
0 0 13 0 0 6 0 0
0 0 0 0 7 0 0 0
0 0 0 14 0 0 0 0
0 21 0 0 0 4 0 0
0 0 15 0 0 0 0 0
0 14 0 0 0 0 0 0
0 0 0 0 0 0 0 0
. B
某人从图的左上角的A点出发,可以向下行走,也可以向右走,直到到达右下角的B
点。在走过的路上,他可以取走方格中的数(取走后的方格中将变为数字0)。
此人从A点到B点共走两次,试找出2条这样的路径,使得取得的数之和为最大。
输入输出格式
输入格式:
输入的第一行为一个整数N(表示N*N的方格图),接下来的每行有三个整数,前两个
表示位置,第三个数为该位置上所放的数。一行单独的0表示输入结束。
输出格式:
只需输出一个整数,表示2条路径上取得的最大的和。
输入输出样例
8
2 3 13
2 6 6
3 5 7
4 4 14
5 2 21
5 6 4
6 3 15
7 2 14
0 0 0
67
四维dp数组:
将这两条路线看成是两个人同时走不同的路线,开一个四维dp数组记录下这两人的坐标。
#include <bits/stdc++.h>
using namespace std;
int mapp[][];
int dp[][][][]; //两条路线,既可以假设为两个人同时走不同的路线,dp[i][j][k][l]表示这两个人走到该点取数的最大和
//mapp[i][j]为第一人的坐标,mapp[k][l]为第二人的坐标
int main()
{
int n, x, y, m;
cin >>n>> x >> y >> m;
while (x != || y != || m != )
{
mapp[x][y] = m;
cin >> x >> y >> m;
}
for (int i = ; i <= n; i++)
for (int j = ; j <= n; j++)
for(int k=;k<=n;k++)
for (int l = ; l <= n; l++)
{ //由于任意一点mapp[i][j]只能由mapp[i-1][j],或者mapp[i][j-1]达到,且控制这两个人的步数相同(即i和j中有且仅有一个数-1,k和l中有且仅有一个数-1),所以总共由4种情况要考虑
dp[i][j][k][l] = max(max(dp[i][j-][k-][l], dp[i][j - ][k][l-]), max(dp[i-][j][k - ][l], dp[i-][j][k][l - ])) + mapp[i][j] + mapp[k][l];
if (i == k && j == l)dp[i][j][k][l] -= mapp[i][j]; //由于方格中的数只能取一次,所以如果这两个人走到了同一个点,mapp[i][j]只能加一次
}
cout << dp[n][n][n][n];
return ;
}
接下来是对以上四维dp的优化,三维dp数组也能解决
定义d[i][j][k]为走了i步,路径a向下走了j步,路径b向下了k步,取数和的最大值;
此时(i-j),(i-k)就是a与b此时到达点的纵坐标;其它的地方都与四维dp类似
#include <bits/stdc++.h>
using namespace std;
int mapp[][];
int f[][][];
int n, x, y, z;
int main()
{
scanf("%d", &n);
memset(f, , sizeof(f));
memset(mapp, , sizeof(mapp));
while (scanf("%d%d%d", &x, &y, &z), x || y || z)
mapp[x][y] = z;
for (int k = ; k <= * n - ; k++)
{
for (int i = ; i <= min(k, n); i++)
{
for (int j = ; j <= min(n, k); j++)
{
f[k][i][j] = max(max(f[k - ][i][j], f[k - ][i][j - ]), max(f[k - ][i - ][j], f[k - ][i - ][j - ]));
if (i == j) f[k][i][j] += mapp[i][k - j + ];
else f[k][i][j] += mapp[i][k - i + ] + mapp[j][k - j + ];
}
}
}
printf("%d\n", f[ * n - ][n][n]);
return ;
}
2018-05-15
洛谷 P1004 方格取数 【多进程dp】的更多相关文章
- 洛谷P1004 方格取数-四维DP
题目描述 设有 N \times NN×N 的方格图 (N \le 9)(N≤9) ,我们将其中的某些方格中填入正整数,而其他的方格中则放入数字 00 .如下图所示(见样例): A 0 0 0 0 0 ...
- 洛谷 - P1004 - 方格取数 - 简单dp
https://www.luogu.org/problemnew/show/P1004 这道题分类到简单dp但是感觉一点都不简单……这种做两次的dp真的不是很懂怎么写.假如是贪心做两次,感觉又不能证明 ...
- 棋盘DP三连——洛谷 P1004 方格取数 &&洛谷 P1006 传纸条 &&Codevs 2853 方格游戏
P1004 方格取数 题目描述 设有N $\times N$N×N的方格图(N $\le 9$)(N≤9),我们将其中的某些方格中填入正整数,而其他的方格中则放入数字00.如下图所示(见样例): A ...
- 洛谷 P1004 方格取数 题解
P1004 方格取数 题目描述 设有 \(N \times N\) 的方格图 \((N \le 9)\),我们将其中的某些方格中填入正整数,而其他的方格中则放入数字\(0\).如下图所示(见样例): ...
- 洛谷P1004 方格取数
网络流大法吼 不想用DP的我选择了用网络流-- 建模方法: 从源点向(1,1)连一条容量为2(走两次),费用为0的边 从(n,n)向汇点连一条容量为2,费用为0的边 每个方格向右边和下边的方格连一条容 ...
- 洛谷 P1004 方格取数 【多线程DP/四维DP/】
题目描述(https://www.luogu.org/problemnew/show/1004) 设有N*N的方格图(N<=9),我们将其中的某些方格中填入正整数,而其他的方格中则放 人数字0. ...
- 洛谷 P1004 方格取数
题目描述 设有N*N的方格图(N<=9),我们将其中的某些方格中填入正整数,而其他的方格中则放 人数字0.如下图所示(见样例): A 0 0 0 0 0 0 0 0 0 0 13 0 0 6 0 ...
- 【动态规划】洛谷P1004方格取数
题目描述 设有N*N的方格图(N<=9),我们将其中的某些方格中填入正整数,而其他的方格中则放 人数字0.如下图所示(见样例): A 0 0 0 0 0 0 0 0 0 0 13 0 0 6 0 ...
- 四维动规 洛谷P1004方格取数
分析:这个题因为数据量非常小,可以直接用四维的DP数组 dp[i][j][k][l]表示第一个人走到位置(i,j),第二个人走到位置[k][l]时所取的数的最大和 状态转移方程可以轻松得出为:dp[i ...
随机推荐
- mysql数据库导出excel xml等格式文件
http://jingyan.baidu.com/article/ac6a9a5e43a62e2b653eac83.html
- python - 添加文件环境变量
#添加 当前文件目录 import sys,os BASE_DIR = os.path.dirname(os.path.dirname(__file__)) sys.path.append(BASE ...
- Python Tools for Machine Learning
Python Tools for Machine Learning Python is one of the best programming languages out there, with an ...
- mac使用influxdb和grafana
mac使用influxdb和grafana influxdb安装以及配置 brew update brew install influxdb ln -sfv /usr/local/opt/influx ...
- ES系列十七、logback+ELK日志搭建
一.ELK应用场景 在复杂的企业应用服务群中,记录日志方式多种多样,并且不易归档以及提供日志监控的机制.无论是开发人员还是运维人员都无法准确的定位服务.服务器上面出现的种种问题,也没有高效搜索日志内容 ...
- sqlserver 日志传送
可以使用日志传送将事务日志不间断地从一个数据库(主数据库)发送到另一个数据库(辅助数据库).不间断地备份主数据库中的事务日志,然后将它们复制并还原到辅助数据库,这将使辅助数据库与主数据库基本保持同步. ...
- python中对列表和循环使用的小练习
#author devilf product_list = [ (), (), (), (), () ] shop_list = [] salary = input('pls enter your s ...
- adb devices检测不到夜神模拟器
1.dos下,cd进入到夜神模拟器的bin目录 代码: nox_adb connect 127.0.0.1:62001 2.dos下,进入进Android SDK下的platform-tools目录 ...
- python接口自动化测试二十三:文件上传
# 以禅道为例: 一.创建一个类,类里面写一个登录方法: import requestsclass LoginZentao(): def __init__(self, s): # 初始化 self.s ...
- linux下安装ruby环境
安装步骤: ruby的shell叫irb,我们可以输入irb -v查看下irb的版本号 1.安装ruby解释器shell: yum install ruby-irb -y Installed: rub ...