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 有非常多从磁盘读取数据的需求,包含顺序读取.随机读取. 为了提高效率.须要人为安排磁盘读取. 然而.在 ...
随机推荐
- 杭电oj2047-2049、2051-2053、2056、2058
2047 阿牛的EOF牛肉串 #include<stdio.h> int main(){ int n,i; _int64 s[]; while(~scanf("%d" ...
- R语言绘制相对性关系图
准备 第一步就是安装R语言环境以及RStudio 图绘制准备 首先安装库文件,敲入指令,回车 install.packages('corrplot') 然后安装excel导入的插件,点击右上角impo ...
- VC版本与VS版本 对照表
Microsoft Visual Studio 6.0 VC6.0 Microsoft Visual Studio .NET 2002: VC7.0 ...
- Application binary interface and method of interfacing binary application program to digital computer
An application binary interface includes linkage structures for interfacing a binary application pro ...
- linux缺页异常处理--内核空间【转】
转自:http://blog.csdn.net/vanbreaker/article/details/7867720 版权声明:本文为博主原创文章,未经博主允许不得转载. 缺页异常被触发通常有两种情况 ...
- java中数组有没有length()方法?string没有lenght()方法?
java中数组有没有length()方法,求数组的长度可以使用数组的length属性. int[] arr={1,2,3,4,5}; int length=arr.length;//求数组的长度 -- ...
- WCF 小程序案例以及序列化的使用
using System;using System.Collections.Generic;using System.Linq;using System.Runtime.Serialization;u ...
- Selenium2+python自动化8-SeleniumBuilder辅助定位元素【转载】
前言 福利来了,对于用火狐浏览器的小伙伴们,你还在为定位元素而烦恼嘛? 上古神器Selenium Builder来啦,哪里不会点哪里,妈妈再也不用担心我的定位元素问题啦!(但是也不是万能,基本上都能覆 ...
- mysql运维必会的一些知识点整理(转自民工哥)
(1)基础笔试命令考察 1.开启MySQL服务 /etc/init.d/mysqld start service mysqld start systemctl start mysqld 2.检测端口是 ...
- (分享别人的一篇好文章,来自jackson0714)30分钟全面解析-SQL事务+隔离级别+阻塞+死锁()
30分钟全面解析-SQL事务+隔离级别+阻塞+死锁 阅读目录 概述: 一.事务 二.锁 三.阻塞 四.隔离级别 五.死锁 以前总是追求新东西,发现基础才是最重要的,今年主要的目标是精通SQL查询和SQ ...