/*********************

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 ***********************/ /*********************** 由于不能往左走,故非常easy使用动态规划实现,由于数据量较小 O(N^3) 的 也能过,就不说了,也比較好写
以下是O(n^2)的
**************************/ //#include <iostream>
#include <algorithm>
#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <vector> using namespace std; typedef long long LL;
typedef long double LD; const int MaxN=102;
const int INF= 1e9; int m,n,T;
int data[MaxN][MaxN],dp[MaxN][MaxN],dpp[MaxN][MaxN]; int main()
{
// cin>>T;
scanf("%d",&T);
int cas=0;
while(T--)
{
//cin>>m>>n;
scanf("%d%d",&m,&n);
for(int i=0;i<m;i++)
for(int j=0;j<n;j++)
{
// cin>>data[i][j];
scanf("%d",&data[i][j]);
dp[i][j]=-INF;
}
dp[0][0]=dpp[0][0]=data[0][0]; //初始化
for(int i=1;i<m;i++) //初始化
dp[i][0]=dpp[i][0]=dp[i-1][0]+data[i][0]; //初始化
for(int j=1;j<n;j++)
{
for(int i=0;i<m;i++)//right
dp[i][j]=dpp[i][j]=max(dp[i][j-1]+data[i][j],dp[i][j]);
for(int i=1;i<m;i++)//down
dp[i][j]=max(dp[i][j],dp[i-1][j]+data[i][j]);
for(int i=m-2;i>=0;i--)//up
dpp[i][j]=max(dpp[i][j],dpp[i+1][j]+data[i][j]);
for(int i=0;i<m;i++)//comebine
dp[i][j]=dpp[i][j]=max(dp[i][j],dpp[i][j]);
}
// cout<<"Case #"<<++cas<<":\n";
printf("Case #%d:\n%d\n",++cas,dp[0][n-1]);
// cout<<dp[0][n-1]<<endl;
}
return 0;
}

版权声明:本文博主原创文章,博客,未经同意不得转载。

百度之星资格赛 hdu 4826 Labyrinth 动态规划的更多相关文章

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

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

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

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

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

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

  4. 2016百度之星 资格赛ABCDE

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

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

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

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

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

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

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

  8. HDU - 6081 2017百度之星资格赛 度度熊的王国战略

    度度熊的王国战略  Accepts: 644  Submissions: 5880  Time Limit: 40000/20000 MS (Java/Others)  Memory Limit: 3 ...

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

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

随机推荐

  1. start with connect by prior学习

    这是oracle中的树查询,查询出来的数据会根据上下级组成树的结构.select * from mw_sys.mwt_pd_deps start with obj_id = '63EBEC8E-E76 ...

  2. 如何打开Windows Server 2003 内存寻址扩展

    本文介绍了如何在系统内存大于4G的情况下,让windows2003 Advanced Server支持大内存的方法: 由于Windows2003 32bit是32位操作系统,当服务器配备内存高达4G时 ...

  3. C#基础学习第三天(.net菜鸟的成长之路-零基础到精通)

    1.复合赋值运算符 += -= *= /= %= 2.关系运算符  > < >= <= == !=  由关系运算符连接的表达式我们称之为关系表达式.  每一个表达式都可以求解出 ...

  4. eclipse在当前项目里面批量替换所有单词

    ctrl+f里面只能单个文件用,要整个项目批量替换. 1. 先选中你要替换字符串, 2. 再菜单栏中找到Search→Text→Project,这样就会在整个项目中查找单词. 3. 然后在Search ...

  5. 最完美的匹配网页中图片 src 部分的正则表达式

    $str='<p style="padding: 0px; margin-top: 0px; margin-bottom: 0px; line-height: 200%;"& ...

  6. php计算剩余时间的自定义函数

    把两个日期格式的字符串转化成unix时间戳,然后相减获得时间戳差,最后判断剩余时间,生成类似(2小时30分钟20秒前发布)这样的时间格式,代码如下: function gettime($time_s, ...

  7. GetMenu返回0解决方法

    在CMainFrame类中找到CMFCMenuBar m_wndMenuBar;这个成员变量,将跟它相关的代码注释掉的话,然后运行,OK.

  8. 网站注册信息的JS全码

    <div class="box_index2">                <div class="login_title">    ...

  9. Linux C 调用MYSQL API 函数mysql_escape_string()转义插入数据

    Title:Linux C 调用MYSQL API 函数mysql_escape_string()转义插入数据 --2013-10-11 11:57 #include <stdio.h> ...

  10. 2015第29周六Spring

    搜了一下Spring相关的经典书籍: <Spring实战(第3版)>从核心的Spring.Spring应用程序的核心组件.Spring集成3个方面,由浅入深.由易到难地对Spring展开了 ...