POJ-1088滑雪,典型的动态规划题,与NYOJ-10skiing一样,但NYOJ上时限是3s,用搜索可以过,但在POJ上就超时了~~
| Time Limit: 1000MS | Memory Limit: 65536k | |
![]() ![]() ![]() ![]() |
http://poj.org/problem?id=1088 |
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
Source
看到POJ上有这道题我就笑了,这跟我在南阳oj(NYOJ)上做的”skiing“一样,NYOJ上难度为5,当时用搜索做出来还蛮激动的
,因为看到数据范围并不是很大,用搜索应该可以过,答案倒是立马出来了,但毫无疑问-超时,这里时限是1s,只能换一种思路了;
动归是大一寒假集训学的,学长发了一个PPT里面包含了POJ上大部分动归题思路代码详解,来看它所提供的两种思路:
(1)
(2)
思路一和二都是差不多的,它只给出了思路,但代码实现起来可能有点困难,我们可以用结构体将坐标高度存放起来,按高度sort排序,然后从小到大遍历判断周围的点的高度关系,然后再用以上两种思路任何一种都可以求出答案;
下面来看超时搜索代码:
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<iostream>
#include<algorithm>
#include<cmath>
using namespace std;
int a[100][100],maxn;
void dfs(int x,int y,int s,int h,int l)
{
if(x<h&&y<l&&a[x][y]!=0)//判断边界条件,然后往四个方向搜索下去;
{
if(a[x-1][y]>a[x][y])
dfs(x-1,y,s+1,h,l);
if(a[x][y-1]>a[x][y])
dfs(x,y-1,s+1,h,l);
if(a[x+1][y]>a[x][y])
dfs(x+1,y,s+1,h,l);
if(a[x][y+1]>a[x][y])
dfs(x,y+1,s+1,h,l);
maxn=max(maxn,s);
}
}
int main()
{
int hang,lie,i,j;
scanf("%d%d",&hang,&lie);
for(i=0; i<hang; i++)
for(j=0; j<lie; j++)
scanf("%d",&a[i][j]);
maxn=0;
for(i=0; i<hang; i++)
for(j=0; j<lie; j++)
dfs(i,j,1,hang,lie);
printf("%d\n",maxn);
return 0;
}//看起来代码简短易懂,但就是超时了;;
AC代码:
<span style="color:#ff0000;">#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<iostream>
#include<algorithm>
#include<cmath>
using namespace std;
const int N=10000+10;
struct node
{
int x,y,h;//坐标及高度
} a[N];
int cmp(node a,node b)//按高度排序;
{
return a.h<b.h;
}
int d[110][110],dp[110][110];
int main()
{
int hang,lie,i,j,k=0;
scanf("%d%d",&hang,&lie);
for(i=1; i<=hang; i++)
for(j=1; j<=lie; j++)
{
a[++k].x=i,a[k].y=j;
scanf("%d",&d[i][j]);
dp[i][j]=1;
a[k].h=d[i][j];
}
sort(a+1,a+k+1,cmp);
int maxx=0;
for(i=1; i<=k; i++)//这里用的是思路一,人人为我型;
{
if(d[a[i].x][a[i].y]>d[a[i].x+1][a[i].y])判断旁边四个方向的高度关系,然后递推公式如下;
dp[a[i].x][a[i].y]=max(dp[a[i].x][a[i].y],dp[a[i].x+1][a[i].y]+1);
if(d[a[i].x][a[i].y]>d[a[i].x-1][a[i].y])
dp[a[i].x][a[i].y]=max(dp[a[i].x][a[i].y],dp[a[i].x-1][a[i].y]+1);
if(d[a[i].x][a[i].y]>d[a[i].x][a[i].y+1])
dp[a[i].x][a[i].y]=max(dp[a[i].x][a[i].y],dp[a[i].x][a[i].y+1]+1);
if(d[a[i].x][a[i].y]>d[a[i].x][a[i].y-1])
dp[a[i].x][a[i].y]=max(dp[a[i].x][a[i].y],dp[a[i].x][a[i].y-1]+1);
maxx=max(dp[a[i].x][a[i].y],maxx);
}
printf("%d\n",maxx);
return 0;
}</span>
POJ-1088滑雪,典型的动态规划题,与NYOJ-10skiing一样,但NYOJ上时限是3s,用搜索可以过,但在POJ上就超时了~~的更多相关文章
- POJ 1088 滑雪(记忆化搜索+dp)
POJ 1088 滑雪 Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 107319 Accepted: 40893 De ...
- POJ 1088 滑雪(记忆化搜索)
滑雪 Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 92384 Accepted: 34948 Description ...
- POJ 1088 滑雪 【记忆化搜索经典】
题目链接:http://poj.org/problem?id=1088 滑雪 Time Limit: 1000MS Memory Limit: 65536K Total Submissions: ...
- POJ 1088 滑雪 -- 动态规划
题目地址:http://poj.org/problem?id=1088 Description Michael喜欢滑雪百这并不奇怪, 因为滑雪的确很刺激.可是为了获得速度,滑的区域必须向下倾斜,而且当 ...
- POJ 1088 滑雪(模板题 DFS+记忆化)
Description Michael喜欢滑雪百这并不奇怪, 因为滑雪的确很刺激.可是为了获得速度,滑的区域必须向下倾斜,而且当你滑到坡底,你不得不再次走上坡或者等待升降机来载你.Michael想知道 ...
- POJ 1088 滑雪 ( DFS+动态规划思想 )
滑雪 Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 79519 Accepted: 29581 Description ...
- OpenJudge/Poj 1088 滑雪
1.链接地址: bailian.openjudge.cn/practice/1088 http://poj.org/problem?id=1088 2.题目: 总Time Limit: 1000ms ...
- poj 1088 滑雪(区间dp+记忆化搜索)
题目链接:http://poj.org/problem?id=1088 思路分析: 1>状态定义:状态dp[i][j]表示在位置map[i][j]可以滑雪的最长区域长度: 2>状态转移方程 ...
- POJ 1088 滑雪 DFS 记忆化搜索
http://poj.org/problem?id=1088 校运会放假继续来水一发^ ^ 不过又要各种复习,功课拉下了许多 QAQ. 还有呀,就是昨天被一个学姐教育了一番,太感谢了,嘻嘻^ ^ 好了 ...
随机推荐
- CoreData修改了数据模型报错 The model used to open the store is incompatible with the one used to create the store
在iOS 6 – Core Data 应用程序的开发过程中, App启动时出现如下异常信息: reason = “The model used to open the store is incompa ...
- HtmlUnit爬取Ajax动态生成的页面内容
HtmlUnit说白了就是一个浏览器,这个浏览器是用Java写的无界面的浏览器,正因为其没有界面,因此执行的速度还是可以滴. HtmlUnit提供了一系列的API,这些API可以干的功能比较多,如表单 ...
- 服务器php-cgi.exe进程过多,导致CPU占用100%的解决方法
再使用iis服务器中经常会出现php-cgi.exe进程过多,导致CPU占用100%,最终造成网站运行过慢甚至卡死的情况,重启iis会好一会,过一段时间久出现这种情况,为什么会出现这种情况呢,应该怎么 ...
- 自動獲取外網IP并發郵件
問題: 公司有一Web系統需開放給香港Office公司查詢資料,但最近動態域名需實名認證, 因系統較小型,非公開大範圍使用,所以再認證一域名也沒多大必要, 所以想定時生成一封能查詢外網IP的郵件發送給 ...
- WPF学习12:基于MVVM Light 制作图形编辑工具(3)
本文是WPF学习11:基于MVVM Light 制作图形编辑工具(2)的后续 这一次的目标是完成 两个任务. 本节完成后的效果: 本文分为三个部分: 1.对之前代码不合理的地方重新设计. 2.图形可选 ...
- Android Learning Note -- AsyncTask浅尝
AsyncTask 实现原理 AsyncTask是Android提供的轻量级异步类,可以直接继承AsyncTask在类中实现异步操作,并提供接口反馈当前的异步执行程度(通过接口实现UI进度更新),最后 ...
- laravel模型关联
hasOne 一对一 用户名-手机号hasMany 一对多 文章-评论belongTo 一对多反向 评论-文章belongsToMany 多对多 用户-角色hasManyThrough 远程 ...
- like SQL注入与防止 (bin2hex unhex)
普通的列表模糊查询,可能会被sql注入利用,造成数据泄漏,严重的甚至导致删表删库! 程序中sql语句拼装: $sql = 'student_name like '"%'.$name.'%&q ...
- nginx 安全配置文档
1.配置文档中有多处明确写出了nginx的配置文件路径,该路径是测试环境中的路径,线上系统的nginx配置文件与文档中所写的路径可能不一样,在进行相关配置时,应以线上配置文件的实际路径为准. 线上系统 ...
- Python3简明教程(一)—— 开始Python之旅
第一个Python程序 作为我们第一个Python程序——打印"Hello World!". 在终端输入Python3进入交互界面: 输入print("Hello W ...


