Labyrinth

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)

Total Submission(s): 152    Accepted Submission(s): 76

Problem Description
度度熊是一仅仅喜欢探险的熊,一次偶然落进了一个m*n矩阵的迷宫,该迷宫仅仅能从矩阵左上角第一个方格開始走,仅仅有走到右上角的第一个格子才算走出迷宫,每一次仅仅能走一格,且仅仅能向上向下向右走曾经没有走过的格子。每个格子中都有一些金币(或正或负,有可能遇到强盗拦路抢劫,度度熊身上金币能够为负,须要给强盗写欠条),度度熊刚開始时身上金币数为0,问度度熊走出迷宫时候身上最多有多少金币?
 
Input
输入的第一行是一个整数T(T < 200)。表示共同拥有T组数据。

每组数据的第一行输入两个正整数m,n(m<=100。n<=100)。

接下来的m行,每行n个整数,分别代表对应格子中能得到金币的数量。每一个整数都大于等于-100且小于等于100。

 
Output
对于每组数据,首先须要输出单独一行”Case #?

:”,当中问号处应填入当前的数据组数,组数从1開始计算。

每组測试数据输出一行,输出一个整数,代表依据最优的打法,你走到右上角时能够获得的最大金币数目。

 
Sample Input
2
3 4
1 -1 1 0
2 -2 4 2
3 5 1 -90
2 2
1 1
1 1
 
Sample Output
Case #1:
18
Case #2:
4
 
Source
 

题目: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的更多相关文章

  1. 2014百度之星资格赛 1004:Labyrinth(DP)

    Labyrinth Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total S ...

  2. 2016百度之星 资格赛ABCDE

    看题:http://bestcoder.hdu.edu.cn/contests/contest_show.php?cid=690 交题:http://acm.hdu.edu.cn/search.php ...

  3. HDU 5688:2016"百度之星" - 资格赛 Problem D

    原文链接:https://www.dreamwings.cn/hdu5688/2650.html Problem D Time Limit: 2000/1000 MS (Java/Others)    ...

  4. HDU 5686:2016"百度之星" - 资格赛 Problem B

    原文链接:https://www.dreamwings.cn/hdu5686/2645.html Problem B Time Limit: 2000/1000 MS (Java/Others)    ...

  5. HDU 5685:2016"百度之星" - 资格赛 Problem A

    原文链接:https://www.dreamwings.cn/hdu5685/2637.html Problem A Time Limit: 2000/1000 MS (Java/Others)    ...

  6. 2017百度之星资格赛 1003:度度熊与邪恶大魔王(DP)

    .navbar-nav > li.active > a { background-image: none; background-color: #058; } .navbar-invers ...

  7. 模拟 2015百度之星资格赛 1003 IP聚合

    题目传送门 /* 模拟水题,排序后找出重复的ip就可以了 */ #include <cstdio> #include <iostream> #include <algor ...

  8. 模拟 百度之星资格赛 1003 IP聚合

    题目传送门 /* 模拟水题,排序后找出重复的ip就可以了 */ #include <cstdio> #include <iostream> #include <algor ...

  9. 2014百度之星资格赛——Disk Schedule

    2014百度拥有明星格比赛--Disk Schedule Problem Description 有非常多从磁盘读取数据的需求,包含顺序读取.随机读取. 为了提高效率.须要人为安排磁盘读取. 然而.在 ...

随机推荐

  1. WPF的webBrowser控件关键代码

    1.根据元素ID获取元素的值. 比如要获取<img class="" id="regimg" src="/register/checkregco ...

  2. 第2章 掌握C++

    参考: https://blog.csdn.net/u014162133/article/details/46573873 1.C++主要特点: 封装性(Encapsulation):把数据与操作数据 ...

  3. 使用matlab判断男声与女声

    (转自) http://wenku.baidu.com/view/1d55480fbe1e650e52ea99a3.html %filename:manwoman.m %different man f ...

  4. 非常好的博客!!!linux内存管理概述【转】

    转自:http://blog.csdn.net/bullbat/article/details/7166140 inux内存管理建立在基本的分页机制基础上,在linux内核中RAM的某些部分将会永久的 ...

  5. 开发框架 springBoot

    1.多个环境的配置文件 在application.yml 中配置需要调用的配置文件 spring: profiles: active: dev 运行方式的,先运行application.yml 再根据 ...

  6. React Native解决Android的WebView无法执行injectedJavaScript代码

    需求 在用WebView组件写一个东西,要求功能:打开web后进行js代码注入. 开发 代码很简单,示例: const js = ` alert(1); alert(2); `; <WebVie ...

  7. 将C#程序做成服务后服务自动停止的问题

    查了好几天,没法调试实在是很难找错误,今天想了半天到事件查看器,提示如下: 说明: 由于未经处理的异常,进程终止. 异常信息: System.NullReferenceException 想了半天,应 ...

  8. PDF笔记:内嵌字体

    前几天投文章的时候,把docx文件保存为PDF提交.但是格式检查始终在报一个关于“font embed”的错误,意思是PDF文件中有些字体没有内嵌. 为了减小文件大小,WORD保存为PDF的时候默认不 ...

  9. 洛谷—— P1869 愚蠢的组合数

    https://www.luogu.org/problemnew/show/1869 题目描述 最近老师教了狗狗怎么算组合数,狗狗又想到了一个问题... 狗狗定义C(N,K)表示从N个元素中不重复地选 ...

  10. 洛谷——P1595 信封问题

    P1595 信封问题 题目描述 某人写了n封信和n个信封,如果所有的信都装错了信封.求所有信都装错信封共有多少种不同情况. 输入输出格式 输入格式: 一个信封数n(n<=20) 输出格式: 一个 ...