ACM-百度之星资格赛之Labyrinth——hdu4826
Labyrinth
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 152 Accepted Submission(s): 76
每组数据的第一行输入两个正整数m,n(m<=100。n<=100)。
接下来的m行,每行n个整数,分别代表对应格子中能得到金币的数量。每一个整数都大于等于-100且小于等于100。
:”,当中问号处应填入当前的数据组数,组数从1開始计算。
每组測试数据输出一行,输出一个整数,代表依据最优的打法,你走到右上角时能够获得的最大金币数目。
2
3 4
1 -1 1 0
2 -2 4 2
3 5 1 -90
2 2
1 1
1 1
Case #1:
18
Case #2:
4
题目:http://acm.hdu.edu.cn/showproblem.php?
pid=4826
百度之星资格赛第四题,看样子非常像搜索,事实上不然,略微分析一下就能够发现会TLE。。。
DP啊,最讨厌的题目类型之中的一个。
于是開始慢慢推,
到一个点 i,j 能够从上走到这,从下走到这,从右走到这。
所以。可是推的时候绝对不能用最新更新的来推。
以提供的第一组測试数据为例:
1 -11
0
2 -24
2
3 51
-90
第一列,仅仅能从上到下:
1
3
6
比較第二列第一行,仅仅能从左面到这 就是 0
第二列第二行。从左到这 和 从上到这,最大值就是1
第二列第三行。从左到这 和 从上到这,最大值就是11
这是从上向下比較的,
接下来从下向上推:
第二列第三行。从左到这 就是11
第二列第二行,从左到这 和 从下到这。最大值就是9
第二列第一行,从左到这 和 从下到这。最大值就是8
最后,比較每一行的最大值。存到数组中
第二列第一行8
第二列第二行9
第二列第三行11
以此类推。整道题就攻克了,
要注意一点,在推到的时候,从上到下和从下到上要分别算。
恩,此代码 耗时15MS 268K内存(C++)
/****************************************
*****************************************
* Author:Tree *
*From :http://blog.csdn.net/lttree *
* Title : Labyrinth *
*Source: hdu 4826 *
* Hint : DP *
*****************************************
****************************************/
#include <stdio.h>
int Map[101][101],dp1[101],dp2[101];
int MAX(int a,int b)
{
return a>b?a:b;
}
int main()
{
int t,T,m,n,i,j;
scanf("%d",&T);
for(t=1;t<=T;++t)
{
scanf("%d%d",&m,&n); for(i=1;i<=m;++i)
for(j=1;j<=n;++j)
scanf("%d",&Map[i][j]); // step1 算出第一列的dp数组
for( i=2;i<=m;++i )
Map[i][1]+=Map[i-1][1]; // 第二列開始向后算
for( j=2;j<=n;++j )
{
// 对应初始化
dp1[0]=dp2[0]=dp1[m+1]=dp2[m+1]=-999999;
// 先从下向上算,存到dp1数组中
for( i=m;i>=1;--i )
dp1[i]=MAX( dp1[i+1],Map[i][j-1])+Map[i][j];
// 再从上向下算,存到dp2数组中
for( i=1;i<=m;++i )
dp2[i]=MAX( dp2[i-1],Map[i][j-1])+Map[i][j];
// 比較 两者。存最大的金钱数量
for( i=1;i<=m;++i )
Map[i][j]=MAX( dp1[i],dp2[i] );
}
printf("Case #%d:\n%d\n",t,Map[1][n]);
}
return 0;
}
ACM-百度之星资格赛之Labyrinth——hdu4826的更多相关文章
- 2014百度之星资格赛 1004:Labyrinth(DP)
Labyrinth Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total S ...
- 2016百度之星 资格赛ABCDE
看题:http://bestcoder.hdu.edu.cn/contests/contest_show.php?cid=690 交题:http://acm.hdu.edu.cn/search.php ...
- HDU 5688:2016"百度之星" - 资格赛 Problem D
原文链接:https://www.dreamwings.cn/hdu5688/2650.html Problem D Time Limit: 2000/1000 MS (Java/Others) ...
- HDU 5686:2016"百度之星" - 资格赛 Problem B
原文链接:https://www.dreamwings.cn/hdu5686/2645.html Problem B Time Limit: 2000/1000 MS (Java/Others) ...
- HDU 5685:2016"百度之星" - 资格赛 Problem A
原文链接:https://www.dreamwings.cn/hdu5685/2637.html Problem A Time Limit: 2000/1000 MS (Java/Others) ...
- 2017百度之星资格赛 1003:度度熊与邪恶大魔王(DP)
.navbar-nav > li.active > a { background-image: none; background-color: #058; } .navbar-invers ...
- 模拟 2015百度之星资格赛 1003 IP聚合
题目传送门 /* 模拟水题,排序后找出重复的ip就可以了 */ #include <cstdio> #include <iostream> #include <algor ...
- 模拟 百度之星资格赛 1003 IP聚合
题目传送门 /* 模拟水题,排序后找出重复的ip就可以了 */ #include <cstdio> #include <iostream> #include <algor ...
- 2014百度之星资格赛——Disk Schedule
2014百度拥有明星格比赛--Disk Schedule Problem Description 有非常多从磁盘读取数据的需求,包含顺序读取.随机读取. 为了提高效率.须要人为安排磁盘读取. 然而.在 ...
随机推荐
- suse10与suse11连接Xmanager的配置
原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://feidandelion.blog.51cto.com/1050439/42217 ...
- centos 资源链接
不时更新.. 安装.启动相关 自动安装的精简的ISO 教你制作属于自己的CentOS 6.4一键自动化安装ISO镜像光盘 initrd介绍 理解 vmlinuz, initrd 和 System.ma ...
- 7.0不通过FileProvider解决调用相机给uri问题异常
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {//严格模式 StrictMode.VmPolicy.Builder builder = ...
- C3P0连接池工具类使用
c3p0的基本连接配置文件 c3p0-config.xml <c3p0-config> <default-config> <property name="dri ...
- C#的Convert.FromBase64String
Invalid length for a Base-64 char array. 异常信息 引用https://stackoverflow.com/questions/2925729/invalid- ...
- jquery mloading
在执行jQuery的ajax时,有的时候请求回来会有较长时间,这个时候,如果什么都没有显示,用户会觉得网站卡住了,所以这个时候,来个mloading会使用户体验更好些. 使用方法很简单 将jquery ...
- Flask插件系列之flask_celery
现在继续学习在集成的框架中如何使用celery. 在Flask中使用celery 在Flask中集成celery需要做到两点: 创建celery的实例对象的名字必须是flask应用程序app的名字,否 ...
- react 使用antd的TreeSelect树选择组件实现多个树选择循环
需求说明,一个帐号角色可以设置管理多个项目的菜单权限 且菜单接口每次只能查询特定项目的菜单数据[无法查全部] 开发思路: 1,获取项目接口数组,得到项目数据 2,循环项目数据,以此为参数递归查询菜单数 ...
- 华农oj 2192: hzk又在打人【CRT合并/待补】
2192: hzk又在打人 Time Limit: 12 Sec Memory Limit: 512 MB Submit: 52 Solved: 1 [Submit][Status][Web Boar ...
- Python的程序结构[8] -> 装饰器/Decorator -> 装饰器浅析
装饰器 / Decorator 目录 关于闭包 装饰器的本质 语法糖 装饰器传入参数 1 关于闭包 / About Closure 装饰器其本质是一个闭包函数,为此首先理解闭包的含义. 闭包(Clos ...