2014百度之星资格赛 1004:Labyrinth(DP)
Labyrinth
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 1507 Accepted Submission(s): 520
每组数据的第一行输入两个正整数m,n(m<=100,n<=100)。接下来的m行,每行n个整数,分别代表相应格子中能得到金币的数量,每个整数都大于等于-100且小于等于100。
每组测试数据输出一行,输出一个整数,代表根据最优的打法,你走到右上角时可以获得的最大金币数目。
#include <iostream>
#include <stdio.h>
using namespace std;
#define inf 0x7fffffff
int a[][];
int dp[][]; //记录走到某一位置的金币最大值
int m,n;
void DP()
{
int i,j,k;
dp[][] = a[][];
for(i=;i<=m;i++) //初始化第一列
dp[i][] = dp[i-][] + a[i][];
for(i=;i<=n;i++){ //每一列 a[][i]
for(j=;j<=m;j++){ //每一列的每一个位置 a[j][i]
//有三种路径到达这个位置。
//1.它左边的位置直接向右走过来。
//2.它左边的位置的上面所有位置向右再一直向下走到这个位置。
//3.它左边的位置的下面所有位置向右再一直向上走到这个位置。
//不断比较,在这个位置处 dp[j][i] 记录以上3条路径的最大值。即为走到这个位置的能拥有的最大金币数。
//这是以 a[j][i] 为重心考虑,遍历到达 a[j][i]的三种路径,求出最大值
int t = dp[j][i-] + a[j][i];
if(t>dp[j][i])
dp[j][i] = t;
for(k=j-;k>=;k--){
//a[k][i-1] --> a[j][i]这个位置所拥有的金币数
t = t-dp[k+][i-]+dp[k][i-]+a[k][i];
if(t>dp[j][i])
dp[j][i] = t;
}
t = dp[j][i-] + a[j][i];
for(k=j+;k<=m;k++){
//a[k][i-1] --> a[j][i]这个位置所拥有的金币数
t = t-dp[k-][i-]+dp[k][i-]+a[k][i];
if(t>dp[j][i])
dp[j][i] = t;
}
}
}
}
int main()
{
int i,j,Case,T;
scanf("%d",&T);
for(Case=;Case<=T;Case++){
scanf("%d%d",&m,&n);
for(i=;i<=m;i++) //输入迷宫,初始化dp[][]
for(j=;j<=n;j++){
scanf("%d",&a[i][j]);
dp[i][j] = -inf;
}
printf("Case #%d:\n",Case);
DP();
printf("%d\n",dp[][n]);
}
return ;
}
贴上超时的DFS代码:
#include <iostream>
#include <stdio.h>
#include <string.h>
using namespace std;
int Max;
int a[][];
bool isv[][];
int dx[] = {,-,};
int dy[] = {,,};
int m,n;
bool judge(int x,int y)
{
if(x< || x>m || y< || y>n)
return true;
if(isv[x][y])
return true;
return false;
}
void dfs(int x,int y,int money)
{
if(x== && y==n){
if(money>Max)
Max=money;
}
int i;
for(i=;i<;i++){
int nx = x+dx[i];
int ny = y+dy[i];
if(judge(nx,ny))
continue;
//可以走
isv[nx][ny] = true;
dfs(nx,ny,money+a[nx][ny]);
isv[nx][ny] = false;
}
}
int main()
{
int i,j,Case,T;
scanf("%d",&T);
for(Case=;Case<=T;Case++){
scanf("%d%d",&m,&n);
for(i=;i<=m;i++)
for(j=;j<=n;j++)
scanf("%d",&a[i][j]);
printf("Case #%d:\n",Case);
Max=;
memset(isv,,sizeof(isv));
isv[][] = true;
dfs(,,a[][]);
printf("%d\n",Max);
}
return ;
}
2014百度之星资格赛 1004:Labyrinth(DP)的更多相关文章
- 2014 百度之星 题解 1004 Labyrinth
Problem Description 度度熊是一仅仅喜欢探险的熊,一次偶然落进了一个m*n矩阵的迷宫,该迷宫仅仅能从矩阵左上角第一个方格開始走,仅仅有走到右上角的第一个格子才算走出迷宫,每一次仅仅能 ...
- 2014百度之星资格赛——Disk Schedule
2014百度拥有明星格比赛--Disk Schedule Problem Description 有非常多从磁盘读取数据的需求,包含顺序读取.随机读取. 为了提高效率.须要人为安排磁盘读取. 然而.在 ...
- 百度之星资格赛 1004 度度熊的午饭时光(01背包+最小序号和+字典序+有bug)
分析 首先声明一下,我的代码有漏洞的,求大神给个正确代码 思路如下: 首先做一遍01背包记录路径并求出最大总分,令path[i][j]表示第i个物品包含在dp[j]的求值过程中.再逆序枚举money, ...
- 2014百度之星资格赛 1001:Energy Conversion(水题,逻辑题)
Energy Conversion Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others ...
- ACM学习历程—BestCoder 2015百度之星资格赛1004 放盘子(策略 && 计算几何)
Problem Description 小度熊喜欢恶作剧.今天他向来访者们提出一个恶俗的游戏.他和来访者们轮流往一个正多边形内放盘子.最后放盘子的是获胜者,会赢得失败者的一个吻.玩了两次以后,小度熊发 ...
- 2014百度之星资格赛—— Xor Sum(01字典树)
Xor Sum Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 132768/132768 K (Java/Others) Total ...
- 2017百度之星资格赛 1003:度度熊与邪恶大魔王(DP)
.navbar-nav > li.active > a { background-image: none; background-color: #058; } .navbar-invers ...
- ACM-百度之星资格赛之Labyrinth——hdu4826
Labyrinth Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total ...
- HDU 5686:2016"百度之星" - 资格赛 Problem B
原文链接:https://www.dreamwings.cn/hdu5686/2645.html Problem B Time Limit: 2000/1000 MS (Java/Others) ...
随机推荐
- windows下C语言编程获取磁盘(分区)使用情况
windows下编程获取磁盘(分区)使用情况 windows下编程获取磁盘(分区)使用情况 GetLogicalDriveStrings函数 使用示例 获取需要的缓冲区长度示例 获取所有驱动器号示例 ...
- httpclient+Jsoup总结
Jsoup.parse解析HTML字符串,如Jsoup.parse("<html><head><title>Firstparse</title> ...
- JSP Servlet WEB生命周期
[转载] JavaWeb的生命周期是由Servlet容器来控制的总的来说分为三个阶段1.启动阶段:加载web应用相关数据,创建ServletContext对象,对Filter和servlet进行初始化 ...
- VQuery选择器
VQUery elements属性,储存选中的元素 参数 typeof的作用 字符串 class ID tagName 函数 事件绑定 对象 直接插入 $函数 绑定事件 click方法 显示隐藏,- ...
- 用extern定义全局变量
1.extern的作用 extern有两个作用,第一个,当它与"C"一起连用时,如: extern "C" void fun(int a, int b); 则告 ...
- STL---list(列表)
Lists将元素按顺序储存在链表中. 与 向量(vectors)相比, 它允许快速的插入和删除,但是随机访问却比较慢. list的类模板声明为 template<class T, class A ...
- 将数据导入带模板EXCEL
在EXCEL模板里设置好样式和格式 点击事件 private void btnReport_Click(object sender, EventArgs e) { ...
- js弹出提示信息,然后跳转到另一页面
<script language="javascript"> alert("您的用户名与密码已成功修改!"); document.locatio ...
- centos6.5 mysql开机启动
可参考:centos6.5 nginx开机启动 /etc/init.d/下添加mysqld文件,内容如下: #!/bin/sh # Copyright Abandoned TCX DataKonsul ...
- 树形dp汇总
HDU 1520 HDU 2196 Codeforces 219D POJ 1155