博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
POJ 1088 滑雪(记忆化搜索)
阅读量:5144 次
发布时间:2019-06-13

本文共 1576 字,大约阅读时间需要 5 分钟。

滑雪
Time Limit: 1000MS   Memory Limit: 65536K
Total Submissions: 92384   Accepted: 34948

Description

Michael喜欢滑雪百这并不奇怪, 因为滑雪的确很刺激。可是为了获得速度,滑的区域必须向下倾斜,而且当你滑到坡底,你不得不再次走上坡或者等待升降机来载你。Michael想知道载一个区域中最长底滑坡。区域由一个二维数组给出。数组的每个数字代表点的高度。下面是一个例子 
1  2  3  4 516 17 18 19 615 24 25 20 714 23 22 21 813 12 11 10 9
一个人可以从某个点滑向上下左右相邻四个点之一,当且仅当高度减小。在上面的例子中,一条可滑行的滑坡为24-17-16-1。当然25-24-23-...-3-2-1更长。事实上,这是最长的一条。

Input

输入的第一行表示区域的行数R和列数C(1 <= R,C <= 100)。下面是R行,每行有C个整数,代表高度h,0<=h<=10000。

Output

输出最长区域的长度。

Sample Input

5 51 2 3 4 516 17 18 19 615 24 25 20 714 23 22 21 813 12 11 10 9

Sample Output

25

 

题目链接:

做的第一道记忆化搜索的题目,每一次把最好的拓展结果记录下来再传回去,挺好理解的

代码:

#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
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
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
=0&&yy
(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
ans) ans=dp[i][j]; printf("%d\n",ans); } return 0;}

转载于:https://www.cnblogs.com/Blackops/p/5875637.html

你可能感兴趣的文章
字符串的查找删除
查看>>
跨域请求
查看>>
NOI2018垫底记
查看>>
快速切题 poj 1002 487-3279 按规则处理 模拟 难度:0
查看>>
判断线段是否相交
查看>>
Codeforces Round #277 (Div. 2)
查看>>
一步步学Mybatis-搭建最简单的开发环境-开篇(1)
查看>>
微信小程序图片上传
查看>>
【更新】智能手机批量添加联系人
查看>>
NYOJ-128前缀式计算
查看>>
centos6.7 配置外网端口映射
查看>>
红外通信基础(含代码)
查看>>
淡定,啊。数据唯一性
查看>>
java并发编程之lock锁
查看>>
深入理解 JavaScript 事件循环(一)— event loop
查看>>
Hive(7)-基本查询语句
查看>>
常用第三方(分享,支付,二维码,语音,推送)
查看>>
Redis快速入门
查看>>
动态绑定时的显示隐藏控制
查看>>
注意java的对象引用
查看>>