POJ 1088 滑雪(记忆化搜索)
| Time Limit: 1000MS | Memory Limit: 65536K | |
| Total Submissions: 92384 | Accepted: 34948 | 
Description
1 2 3 4 5 16 17 18 19 6 15 24 25 20 7 14 23 22 21 8 13 12 11 10 9
一个人可以从某个点滑向上下左右相邻四个点之一,当且仅当高度减小。在上面的例子中,一条可滑行的滑坡为24-17-16-1。当然25-24-23-...-3-2-1更长。事实上,这是最长的一条。
Input
Output
Sample Input
5 5
1 2 3 4 5
16 17 18 19 6
15 24 25 20 7
14 23 22 21 8
13 12 11 10 9
Sample Output
25
题目链接:POJ 1088
做的第一道记忆化搜索的题目,每一次把最好的拓展结果记录下来再传回去,挺好理解的
代码:
#include<stdio.h>
#include<iostream>
#include<algorithm>
#include<cstdlib>
#include<sstream>
#include<cstring>
#include<bitset>
#include<string>
#include<deque>
#include<stack>
#include<cmath>
#include<queue>
#include<set>
#include<map>
using namespace std;
#define INF 0x3f3f3f3f
#define CLR(x,y) memset(x,y,sizeof(x))
#define LC(x) (x<<1)
#define RC(x) ((x<<1)+1)
#define MID(x,y) ((x+y)>>1)
typedef pair<int,int> pii;
typedef long long LL;
const double PI=acos(-1.0);
const int N=110;
int pos[N][N],direct[4][2]={{0,1},{0,-1},{1,0},{-1,0}};
int dp[N][N];
int n,m;
int dfs(int x,int y)
{
if(dp[x][y])
return dp[x][y];
else
{
int maxm=0;
for (int i=0; i<4; ++i)
{
int xx=x+direct[i][0];
int yy=y+direct[i][1];
if(xx>=0&&xx<n&&yy>=0&&yy<m&&pos[xx][yy]<pos[x][y])
maxm=max<int>(maxm,dfs(xx,yy));
}
return dp[x][y]=maxm+1;
}
}
int main(void)
{
int i,j;
while (~scanf("%d%d",&n,&m))
{
CLR(dp,0); for (i=0; i<n; ++i)
for (j=0; j<m; ++j)
scanf("%d",&pos[i][j]); for (i=0; i<n; ++i)
for (j=0; j<m; ++j)
dfs(i,j); int ans=1;
for (i=0; i<n; ++i)
for (j=0; j<m; ++j)
if(dp[i][j]>ans)
ans=dp[i][j]; printf("%d\n",ans);
}
return 0;
}
POJ 1088 滑雪(记忆化搜索)的更多相关文章
- POJ 1088 滑雪(记忆化搜索+dp)
		POJ 1088 滑雪 Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 107319 Accepted: 40893 De ... 
- POJ 1088 滑雪 (记忆化搜索)
		题目链接:http://poj.org/problem?id=1088 题意很好懂,就是让你求一个最长下降路线的长度. dp[i][j]记录的是i j这个位置的最优的长度,然后转移方程是dp[i][j ... 
- POJ 1088 滑雪 记忆化DP
		滑雪 Time Limit: 1000MS Memory Limit: 65536K Description Michael喜欢滑雪百这并不奇怪, 因为滑雪的确很刺激.可是为了获得速度 ... 
- POJ 1088 DP=记忆化搜索
		话说DP=记忆化搜索这句话真不是虚的. 面对这道题目,题意很简单,但是DP的时候,方向分为四个,这个时候用递推就好难写了,你很难得到当前状态的前一个真实状态,这个时候记忆化搜索就派上用场啦! 通过对四 ... 
- POJ 1088 滑雪 记忆化优化题解
		本题有人写是DP,只是和DP还是有点区别的,应该主要是记忆化 Momoization 算法. 思路就是递归,然后在递归的过程把计算的结果记录起来,以便后面使用. 非常经典的搜索题目,这样的方法非常多题 ... 
- tyvj 1004 滑雪 记忆化搜索
		滑雪 Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://www.tyvj.cn/p/1004 Description trs喜欢滑雪.他来 ... 
- 洛谷-P1434 [SHOI2002]滑雪 (记忆化搜索)
		题意:有一个\(R*C\)的矩阵,可以从矩阵中的任意一个数开始,每次都可以向上下左右选一个比当前位置小的数走,求走到\(1\)的最长路径长度. 题解:这题很明显看到就知道是dfs,但是直接爆搜会TLE ... 
- poj 1088 (dfs+记忆化) 滑雪
		题目;http://poj.org/problem?id=1088 感觉对深搜还不太熟练,所以练习一下,类似于连连看的那题,注意的是所求的是最大达长度,并不是从最大的或者最小的点出发得到的就是最长的路 ... 
- POJ 1390 Blocks(记忆化搜索+dp)
		POJ 1390 Blocks 砌块 时限:5000 MS 内存限制:65536K 提交材料共计: 6204 接受: 2563 描述 你们中的一些人可能玩过一个叫做“积木”的游戏.一行有n个块 ... 
- poj 1390 Blocks (记忆化搜索)
		Blocks Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 4318 Accepted: 1745 Descriptio ... 
随机推荐
- javascript基础总结
			一.语法 ------------------------------ javascript中的一切(变量.函数名和操作符)都区分大小写. 标识符:就是指变量.函数.属性的名字,标识符要求如下 1 第 ... 
- 使用osgconv工具对模型进行旋转
			osgconv -o 90-1,0,0 --use-world-frame src.3ds dst.3ds 视线方向沿X轴正方向,将src.3ds顺时针旋转90度,保存为dst.3ds 
- cf112a(水题)
			题目很简单..不过题意好像有点难懂... 题意:判定一个数能否被一个幸运数整除,循环一遍4到n/4,若存在i为幸运数且被n整除输出yes,反之输出no... 代码如下: #include <bi ... 
- 禅道bug安装报错
			[root@lnmp src]# grep "session.save" /etc/php.ini ; http://php.net/session.save-handler se ... 
- nginx 匹配.zip .apk 结尾的文件  直接下载
			server { listen 80; server_name ok.xidd.com; index index.html index.htm index.php; root /alidata/www ... 
- Phpcms V9网站从本地上传到服务器需要修改的地方
			网站在本地做好后要迁移到服务器上:网站在发展的过程中,很可能多次的修改域名.那么在Phpcms V9中我们要怎么进行设置呢 请进行以下步骤的修改: Phpcms V9网站上传到服务器具体方法如下: ... 
- 在HTML中优雅的生成PDF
			关键代码<script type=</text> </para> <para align=" value=" ... 
- vijos 1037 ***
			链接:点我 #include <cstdio> #include <cstring> #include <algorithm> #include <iostr ... 
- 不自动生成Android Dependencies的解决方式
			今天遇到的奇怪问题是网上下载的demo导入第三方包运行后Android: NoClassDefFoundError的错误,原因是第三方的jar包并没有打包进apk里,运行是肯定要出错的. 网上百度了N ... 
- [转载]GMM的EM算法实现
			在聚类算法K-Means, K-Medoids, GMM, Spectral clustering,Ncut一文中我们给出了GMM算法的基本模型与似然函数,在EM算法原理中对EM算法的实现与收敛性证明 ... 
