百度之星资格赛 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 有非常多从磁盘读取数据的需求,包含顺序读取.随机读取. 为了提高效率.须要人为安排磁盘读取. 然而.在 ...
随机推荐
- php5.3.3安装mongo扩展
/usr/bin/phpize./configure --with-php-config=/usr/bin/php-configmake && make install/usr/sbi ...
- LayoutInflater.inflate() 参数研究
参考连接:http://blog.csdn.net/lovexieyuan520/article/details/9036673 http://www.2cto.com/kf/201407/31305 ...
- WAJUEJI which home strong!
算法:搜索+优先队列 描述 在一个山沟里,姐弟俩同时考上了大学.但由于家里拮据,所以这并不是什么好消息.父亲对孩子说:我就是砸锅卖铁也要把你们姐俩供出来. 当时的姐姐已经决定放弃上学的机会. 没想到第 ...
- 转载:详解CSS选择器、优先级与匹配原
转载网址:http://polaris1119.javaeye.com/blog/764428 文章就CSS选择器的优先级问题做了一些总结,严格来讲,选择器的种类可以分为三种:标签名选择器.类选择器和 ...
- discuz 万能SQL查询调用语句写法
首先在最底层source\class\table写入底层安全调用文件例如:table_common_friendlink.php 代码: <?php /** * [Discuz!] (C)200 ...
- C++快速排序实现(quicksort)
quicksort:分治思想. 分解:数组A[p, r)被划分成两个子数组A[pq) 和 A[q+1, r),使得A[pq)中的每个元素小于等于A[q], A[q]也小于A[q+1r)中的每个元素.q ...
- C语言+ODBC+SQL 操作(向SQL里面添加数据)
为了节省时间,我就引用上一节的数据库的表和C语言的结构体数组,在结构体数组中添加数据,清空数据库数据. 第一步查询:SQLBindParameter函数的用法. SQLRETURN SQLBindPa ...
- 【转】Nginx配置文件详细说明
Nginx配置文件详细说明 在此记录下Nginx服务器nginx.conf的配置文件说明, 部分注释收集与网络. #运行用户user www-data; #启动进程,通常设置成和cpu的数量相等 ...
- data-theme 几种值的样式
代码片段: <div data-role="page"> <div data-role="header"> <h1>The ...
- Set的并集
public static void main(String[] args) { Set<Long> old = new HashSet<>(); for (int i = 0 ...