URAL 1029 Ministry
思路:
dp+记录路径
状态:dp[i][j]表示到(i,j)这个位置为止的最少花费
初始状态:dp[1][i]=a[1][i](1<=i<=m)
状态转移:dp[i][j]=a[i][j]+max(dp[i-1][j],dp[i][j-1],dp[i][j+1])(注意扫的方向不同)
数组记录上一次的坐标,最后递归输出
代码:
- #include<bits/stdc++.h>
- using namespace std;
- #define ll long long
- #define pb push_back
- #define mem(a,b) memset(a,b,sizeof(a))
- const int N=;
- const int INF=0x3f3f3f3f;
- int a[N][N];
- int dp[N][N];
- pair<int,int> pre[N][N];
- void dfs(int x,int y){
- if(x==-||y==-)return ;
- dfs(pre[x][y].first,pre[x][y].second);
- cout<<y<<' ';
- }
- int main(){
- ios::sync_with_stdio(false);
- cin.tie();
- int n,m;
- mem(a,INF);
- mem(dp,INF);
- cin>>n>>m;
- for(int i=;i<=n;i++){
- for(int j=;j<=m;j++){
- cin>>a[i][j];
- }
- }
- for(int i=;i<=n;i++)for(int j=;j<=m;j++)pre[i][j].first=-,pre[i][j].second=-;
- for(int i=;i<=m;i++)dp[][i]=a[][i];
- for(int i=;i<=n;i++){
- for(int j=;j<=m;j++){
- if(dp[i][j]>a[i][j]+dp[i-][j]){
- dp[i][j]=a[i][j]+dp[i-][j];
- pre[i][j].first=i-;
- pre[i][j].second=j;
- }
- if(dp[i][j]>a[i][j]+dp[i][j-]){
- dp[i][j]=a[i][j]+dp[i][j-];
- pre[i][j].first=i;
- pre[i][j].second=j-;
- }
- }
- for(int j=m;j>=;j--){
- if(dp[i][j]>a[i][j]+dp[i-][j]){
- dp[i][j]=a[i][j]+dp[i-][j];
- pre[i][j].first=i-;
- pre[i][j].second=j;
- }
- if(dp[i][j]>a[i][j]+dp[i][j+]){
- dp[i][j]=a[i][j]+dp[i][j+];
- pre[i][j].first=i;
- pre[i][j].second=j+;
- }
- }
- }
- int ans=INF,id=;
- for(int i=;i<=m;i++){
- if(dp[n][i]<ans){
- ans=dp[n][i];
- id=i;
- }
- }
- int x=n,y=id;
- dfs(x,y);
- cout<<endl;
- return ;
- }
URAL 1029 Ministry的更多相关文章
- DP+路径 URAL 1029 Ministry
题目传送门 /* 题意:就是从上到下,找到最短路,输出路径 DP+路径:状态转移方程:dp[i][j] = min (dp[i-1][j], dp[i][j-1], dp[i][j+1]) + a[[ ...
- Ural 1029 Ministry 题解
目录 Ural 1029 Ministry 题解 题意 题解 程序 Ural 1029 Ministry 题解 题意 给定一个\(n\times m(1\le n \le10,1\le m \le50 ...
- URAL 1732 Ministry of Truth(KMP)
Description In whiteblack on blackwhite is written the utterance that has been censored by the Minis ...
- URAL 1029
题目大意:M层N列的矩阵(各元素均为正整数),找出一个路径从第一层到达第M层,使得路径上的所有数的和是所有可达路径中最小的,每次上到下一层以后就不能再上去,依次输出路径上的各点在所在层的列数. KB ...
- URAL 1732. Ministry of Truth ( KMP 多模式串匹配 )
问在第一个串中删掉几个字符能否得到第二个串.注意在第二个串中不连续的单词在第一个串中也必须不连续. 一组数据: Input: abababbbbababbb aba ab Output: I HAVE ...
- URAL - 1029 dp
题意: n层楼,每层楼有m个房间.找出一个路径从第一层到达第M层,使得路径上的所有数的和是所有可达路径中最小的,每次上到下一层以后就不能再上去,依次输出路径上的各点在所在层的列数. 题解: 参考链接: ...
- URAL DP第一发
列表: URAL 1225 Flags URAL 1009 K-based Numbers URAL 1119 Metro URAL 1146 Maximum Sum URAL 1203 Scient ...
- ural 1075. Thread in a Space
1075. Thread in a Space Time limit: 1.0 secondMemory limit: 64 MB There are three points in a 3-dime ...
- BZOJ 1029 建筑抢修 贪心+堆
又搞了一晚上OI,编了两道BZOJ和几道NOI题库,临走之前写两篇感想 noip越来越近了,韩大和clove爷已经开始停课虐我们了... 1029: [JSOI2007]建筑抢修 Time Limit ...
随机推荐
- http协议基础(四)http状态码
一:http状态码 表示客户端http请求的返回结果.标记服务器端的处理是否正常.通知出现的错误等工作 状态码的类别如下: http状态码种类繁多,大概有60多种,实际上经常使用的只有14种,下面为一 ...
- “System.Data”中不存在类型或命名空间名称“TypedTableBase”
错误 1 命名空间“System.Data”中不存在类型或命名空间名称“TypedTableBase”(是否缺少程序集引用?) 解决方案 因为是把强类型DataSet文件绑定报表的项目中出现的错误, ...
- Linux基础命令---cpio
cpio 从归档中复制文件,或者复制文件到归档中.此命令的适用范围:RedHat.RHEL.Ubuntu.CentOS.SUSE.openSUSE.Fedora. Cpio命令有三种工作模式: 1)c ...
- Js基础知识1-数组操作全解
数组操作全解 js变量类型 var string; var name = "student",age=12; //underfined.null.boolean.string.nu ...
- 华为C/C++笔试题&答案
1.static有什么用途?(请至少说明两种) 1)在函数体,一个被声明为静态的变量在这一函数被调用过程中维持其值不变. 2) 在模块内(但在函数体外),一个被声明为静态的变量可以被模块内所用函数访问 ...
- python构造栈结构
栈:是一种先进后出的数据结构:本片文章,我们用python的面向对象来构造这样的数据结构. 栈中的每一个数据除了存储当前的数值外,还存储着当前数值下一个数据的类型(注意不是下一个数据的数值). cla ...
- ELK学习笔记之Logstash详解
0x00 Logstash概述 官方介绍:Logstash is an open source data collection engine with real-time pipelining cap ...
- Non-resolvable parent POM
今天导入公司项目,maven聚合项目,但是项目目录结构不正确,内层的项目的parent不是外层项目,这个......有点无语,结果导入直接报错.同事说,我们导入是好好的啊,原来他们用的是eclipse ...
- AS不能在手机上现在调试软件
这两天遇到的一个问题,(android studio2.0以上的版本),在在线调试应用的时候,将手机上的此程序卸载了,然后准备重新再AS中将这个程序推送到手机上,可是这时候发现不能推送,Log显示什么 ...
- Package libvirt was not found in the pkg-config search path
关于pip安装libvirt-python的时候提示Package libvirt was not found in the pkg-config search path的问题解决方法 1.一开始以为 ...