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 有非常多从磁盘读取数据的需求,包含顺序读取.随机读取. 为了提高效率.须要人为安排磁盘读取. 然而.在 ...
随机推荐
- 小Z爱图论(NOIP信(sang)心(bin)赛)From FallDream
题目: 小Z最近喜欢上了图论,于是他研究了一下图的连通性问题.但是他遇到了一个难题. 给定一个n个点的有向图,求有多少点对(i,j)满足从i点出发能到达点j ? 小Z仅会简单的朴素算法,所以他想问问你 ...
- MAC删除目录下的“.svn”文件的方法
http://bbs.feng.com/read-htm-tid-7803070.html MAC删除目录的“.svn”文件:打开终端,进到所在的目录,然后出入一下代码find . -name &qu ...
- ASP.NET Code First Update-Database
问题描述: 复制了一个模块化的MVC5的项目,模块化的解释是说不同功能的模块分开来放的. 明确每个模块都是做什么工作的. 首先最基本的,就是根据Apps.Models模块来创建数据库了. 做法是卸载A ...
- MSSQL—字符串分离(Split函数)
前面提到了记录合并,有了合并需求肯定也会有分离需求,说到字符串分离,大家肯定会想到SPLIT函数,这个在.NET,Java和JS中都有函数,很可惜在SQL SERVER中没有,我们只能自己来写这么一个 ...
- Python与数据库[1] -> 数据库接口/DB-API[1] -> MySQL 适配器
MySQL适配器 / MySQL Adapter MySQL是一种关系型数据库,下面主要介绍利用如何利用Python的MySQL适配器来对MySQL进行操作,其余内容可参考文末相关阅读. 1 MySQ ...
- 搭建负载均衡的环境(利用虚拟机上的四台centos)
以下转载: 准备 l 系统:Centos6 (三台) l 负载均衡:LVS + keepalived l 服务器1:Http l 服务器2:Http ip配置 1.VIP(virtual ip): ...
- oracle case else end
--简单Case函数 CASE sex WHEN '1' THEN '男' WHEN '2' THEN '女' ELSE '其他' END --Case搜索函数 CASE WHEN sex = '1' ...
- Java多线程中的异常处理
在java多线程程序中,所有线程都不允许抛出未捕获的checked exception,也就是说各个线程需要自己把自己的checked exception处理掉.这一点是通过java.lang.Run ...
- JDK内置性能监测工具使用
Java自带的性能监测工具用法简介——jstack.jconsole.jinfo.jmap.jdb.jsta.jvisualvmJDK内置工具使用 一.javah命令(C Header and Stu ...
- Redis(二)linux下redis安装
上篇讲解了redis在windows下的安装,接下来看看在linux下如何安装redis(纯菜鸟入门级别)? (1)redis的下载及编译 这里,首先进入存放文件目录(我的云服务器的是:cd /jel ...