百度之星资格赛 hdu 4826 Labyrinth 动态规划
/********************* 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 动态规划的更多相关文章
- 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) ...
- 2016百度之星 资格赛ABCDE
看题:http://bestcoder.hdu.edu.cn/contests/contest_show.php?cid=690 交题:http://acm.hdu.edu.cn/search.php ...
- 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 ...
- HDU - 6081 2017百度之星资格赛 度度熊的王国战略
度度熊的王国战略 Accepts: 644 Submissions: 5880 Time Limit: 40000/20000 MS (Java/Others) Memory Limit: 3 ...
- 2014百度之星资格赛——Disk Schedule
2014百度拥有明星格比赛--Disk Schedule Problem Description 有非常多从磁盘读取数据的需求,包含顺序读取.随机读取. 为了提高效率.须要人为安排磁盘读取. 然而.在 ...
随机推荐
- AD域属性对照表
查看文章 AD属性对照表(一)[AD域][属性] 2011年08月25日 星期四 19:36AD属性对照表家庭电话 :“常规”标签 姓 Sn Y 名 gi ...
- Js打开新窗口拦截问题整理
一.js打开新窗口,经常被拦截 //js打开新窗口,经常被拦截 //指定本窗口打开,可以使用 window.open('http://www.tianma3798.cn', '_self'); //不 ...
- Windows 设置时间同步
1.Windows Server 2008 r2 注:{}内是你要同步的外部服务器地址,例如复旦的时间同步服务器地址为:ntp.fudan.edu.cn,则完整命令如下: w32tm /config ...
- 策略模式Strategy(对象行为型)
原文地址:http://blog.csdn.net/hguisu/article/details/75582491.策略模式:定义一系列的算法,把每一个算法封装起来, 并且使它们可相互替换.本模式使得 ...
- 对于没有Command属性时,怎么来达到相同的效果
控件是第三方Telerik控件 CellEditEnded事件想写成Command{Binding CellEditEndedCommand} 这样的效果如下代码 需要引用 System.Wind ...
- sql语法图
- c++虚函数的学习
1.虚函数 #include<iostream.h> class Base { public: void print() { cout<<"Base"< ...
- idea intellij 快捷键(ubuntu版本)
S + C + T 创建测试类 A + F12 开启终端 C + F12 查看类中的方法属性 ----随时更新,记录快捷方式
- php页面显示空白
问题: 本人php初学者,网站下载wamp5,安装好之后,测试环境是否正常,用phpinfo(),但是页面不能正确显示. 1.显示连接错误 2.显示空白页 解决方法: 一.显示连接错误 步骤: 1.p ...
- gtk程序如何进行编译
程序名: gtk_example.c 生成目标文件:gtk_example gcc gtk_example.c -o gtk_example `pkg-config --libs --cfl ...