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 有非常多从磁盘读取数据的需求,包含顺序读取.随机读取. 为了提高效率.须要人为安排磁盘读取. 然而.在 ...
随机推荐
- WPF的webBrowser控件关键代码
1.根据元素ID获取元素的值. 比如要获取<img class="" id="regimg" src="/register/checkregco ...
- 第2章 掌握C++
参考: https://blog.csdn.net/u014162133/article/details/46573873 1.C++主要特点: 封装性(Encapsulation):把数据与操作数据 ...
- 使用matlab判断男声与女声
(转自) http://wenku.baidu.com/view/1d55480fbe1e650e52ea99a3.html %filename:manwoman.m %different man f ...
- 非常好的博客!!!linux内存管理概述【转】
转自:http://blog.csdn.net/bullbat/article/details/7166140 inux内存管理建立在基本的分页机制基础上,在linux内核中RAM的某些部分将会永久的 ...
- 开发框架 springBoot
1.多个环境的配置文件 在application.yml 中配置需要调用的配置文件 spring: profiles: active: dev 运行方式的,先运行application.yml 再根据 ...
- React Native解决Android的WebView无法执行injectedJavaScript代码
需求 在用WebView组件写一个东西,要求功能:打开web后进行js代码注入. 开发 代码很简单,示例: const js = ` alert(1); alert(2); `; <WebVie ...
- 将C#程序做成服务后服务自动停止的问题
查了好几天,没法调试实在是很难找错误,今天想了半天到事件查看器,提示如下: 说明: 由于未经处理的异常,进程终止. 异常信息: System.NullReferenceException 想了半天,应 ...
- PDF笔记:内嵌字体
前几天投文章的时候,把docx文件保存为PDF提交.但是格式检查始终在报一个关于“font embed”的错误,意思是PDF文件中有些字体没有内嵌. 为了减小文件大小,WORD保存为PDF的时候默认不 ...
- 洛谷—— P1869 愚蠢的组合数
https://www.luogu.org/problemnew/show/1869 题目描述 最近老师教了狗狗怎么算组合数,狗狗又想到了一个问题... 狗狗定义C(N,K)表示从N个元素中不重复地选 ...
- 洛谷——P1595 信封问题
P1595 信封问题 题目描述 某人写了n封信和n个信封,如果所有的信都装错了信封.求所有信都装错信封共有多少种不同情况. 输入输出格式 输入格式: 一个信封数n(n<=20) 输出格式: 一个 ...