dfs+dp思想的结合------hdu1078
首先是题目的意思:
从一个正方形的0,0点开始走,只能横着走,竖着走,最多走k步,下一个点的数一定要比当前这个点的值大,每走一步,就加上下一个点的数据,问数据最大能有多少。
首先遇到这种题目,走来走去的,一开始想到的是搜索,但是搜索我们搜的很多是路径,能走到那个点的最短路,但是这道题目不一样。
首先要注意的一点是,如果没有条件的搜索,那就是枚举。只有搜遍了才能得到最后的解。
1s题,只是搜的话肯定TLE了。
所以我们想到的自然就是dp了。dp的好处是什么?就是能减少不必要的搜索。用已知的结果减少当前路径搜索的时间。
几个要点:
1、只能从0,0开始走,所以已经减少了很多复杂了,不要傻乎乎的全部循环。
2、注意dfs时候的边界判断。
3、更新值时不要忘记加上当前自己的值。
状态转移方程
dp[][] = max(所有可以从当前点走到的点的dfs的结果集)
初始值肯定是0没问题
最后dp【0】【0】就是结果了。
#include<cstdio>
#include<cstdlib>
#include<iostream>
#include<algorithm> using namespace std;
/*dfs+dp,hdu1078*/ int maps[][];//用来保存原数据
int dp[][];//dp数组
int k;//最多走的步数
int n;//区域大小 int update(int x,int y)
{
int i,j;
int fromX,toX;
int fromY,toY;
int maxTemp=;
int temp; //判断边界条件
if(dp[x][y])
return dp[x][y]; if(x-k < )
fromX = ;
else
fromX = x-k; if(x+k >= n)
toX = n-;
else
toX = x+k; if(y-k < )
fromY = ;
else
fromY = y-k; if(y+k >= n)
toY = n-;
else
toY = y+k; for (i = fromX; i <= toX; i++)
{
if(i!=x && maps[i][y] > maps[x][y])
{
temp = update(i,y);
if(temp > maxTemp)
maxTemp = temp;
}
} for (j = fromY; j <= toY; j++)
{
if(j!=y && maps[x][j] > maps[x][y])
{
temp = update(x,j);
if(temp > maxTemp)
maxTemp = temp;
}
} dp[x][y] = maxTemp + maps[x][y];
return dp[x][y];
} int main()
{
int i,j;//循环变量
int maxNumber=;//记录结果 while (true)
{
cin>>n>>k;
if(n==- && k==-)
break;
memset(dp,,sizeof(dp));
//输入数据
for (i = ; i < n; i++)
for (j = ; j < n; j++)
cin>>maps[i][j]; //只能从0.0点开始走
maxNumber = update(,); cout<<maxNumber<<endl;
} return ;
}
dfs+dp思想的结合------hdu1078的更多相关文章
- 到底什么是dp思想(内含大量经典例题,附带详细解析)
期末了,通过写博客的方式复习一下dp,把自己理解的dp思想通过样例全部说出来 说说我所理解的dp思想 dp一般用于解决多阶段决策问题,即每个阶段都要做一个决策,全部的决策是一个决策序列,要你求一个 最 ...
- HDU1978How Many Ways 记忆化dfs+dp
/*记忆化dfs+dp dp[i][j]代表达到这个点的所有路的条数,那么所有到达终点的路的总数就是这dp[1][1]加上所有他所能到达的点的 所有路的总数 */ #include<stdio. ...
- hdu 3030 Increasing Speed Limits (离散化+树状数组+DP思想)
Increasing Speed Limits Time Limit: 2000/10000 MS (Java/Others) Memory Limit: 32768/32768 K (Java ...
- 记忆化搜索(DFS+DP) URAL 1223 Chernobyl’ Eagle on a Roof
题目传送门 /* 记忆化搜索(DFS+DP):dp[x][y] 表示x个蛋,在y楼扔后所需要的实验次数 ans = min (ans, max (dp[x][y-i], dp[x-1][i-1]) + ...
- 记忆化搜索(DFS+DP) URAL 1501 Sense of Beauty
题目传送门 /* 题意:给了两堆牌,每次从首部取出一张牌,按颜色分配到两个新堆,分配过程两新堆的总数差不大于1 记忆化搜索(DFS+DP):我们思考如果我们将连续的两个操作看成一个集体操作,那么这个操 ...
- DP思想在斐波那契数列递归求解中的应用
斐波那契数列:1, 1, 2, 3, 5, 8, 13,...,即 f(n) = f(n-1) + f(n-2). 求第n个数的值. 方法一:迭代 public static int iterativ ...
- 【cf1111】C. Creative Snap (dfs+dp)
传送门 简单的dfs+dp即可解决.根本不用动态开点 /* * Author: heyuhhh * Created Time: 2019/11/13 10:12:42 */ #include < ...
- HDU1078 FatMouse and Cheese(DFS+DP) 2016-07-24 14:05 70人阅读 评论(0) 收藏
FatMouse and Cheese Problem Description FatMouse has stored some cheese in a city. The city can be c ...
- hdu1078 dfs+dp(记忆化搜索)搜索一条递增路径,路径和最大,起点是(0,0)
#include<bits/stdc++.h> using namespace std; typedef unsigned int ui; typedef long long ll; ty ...
随机推荐
- Cash Machine
Problem Description A Bank plans to install a machine for cash withdrawal. The machine is able to de ...
- 表单提交是ajax提交,PC提交没问题但是手机提交就会一直跳到error,并且也没状态码一直是0
真是被自己蠢死了button标签他会自动提交刷新页面 <form id="baoming_from"> <p>请填写您的个人信息</p> < ...
- C语言介绍
以下东东转自百度百科 C语言是一种计算机程序设计语言,它既具有高级语言的特点,又具有汇编语言的特点.它由美国贝尔实验室的Dennis M. Ritchie于1972年推出,1978年后,C语言已先后被 ...
- 利用文本编辑器输入课堂上练习的Hello.java,并在JDK环境下编译和运行。
- why TCP guarentee delivery?
Simple idea: just use a TIMEOUT, if no answer after a certain seconds, just re-deliver!
- 关于C++中虚函数表存放位置的思考
其实这是我前一段时间思考过的一个问题,是在看<深入探索C++对象模型>这本书的时候我产生的一个疑问,最近在网上又看到类似的帖子,贴出来看看: 我看到了很多有意思的答案,都回答的比较好,下面 ...
- hr定位
css里写 <style> hr{ position:relative; top: 500px; } </style> 重要!!! hr不能绝对定位, 只能相对定位,所以 hr ...
- Android得到视频缩略图
视频缩略图,可以通过接口类 MediaMetadataRetriever 来实现 具体可以看代码片段 public Bitmap getVideoThumbnail(String filePath) ...
- VB 要求对象
vDoc = WebBrowser1.Document '提示要求对象 Set vDoc = WebBrowser1.Document '正确执行
- Java学习笔记之I/O流(读取压缩文件以及压缩文件)
1.读取压缩文件:ZipInputStream 借助ZipFile类的getInputStream方法得到压缩文件的指定项的内容,然后传递给InputStreamReader类的构造方法,返回给Buf ...