北大poj-1088
Time Limit: 1000MS | Memory Limit: 65536K | |
Total Submissions: 88484 | Accepted: 33177 |
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 分析:看到这个题感觉好简单,直接递归就写好了,提交居然TLE了。那么就需要一些小技巧了,先干掉动态分配二维数组,然后定义一个二维数组gawDis[]用来记录对应节点的最长路径,后面再用到这个节点的时候就不需要再计算了。
综上:递归+记忆化dfs搜索
#include <stdio.h>
#include <stdlib.h> #define MAXNUM 101 int gawMap[MAXNUM][MAXNUM];
int gawRow;
int gawColumn;
int gawDis[MAXNUM][MAXNUM]; int max(int a, int b)
{
if(a>b)
return a;
else
return b;
} int Ski(int wlasthigh, int *awlastposition)
{
int awposition[] = {};
int wleft = ;
int wright = ;
int wup = ;
int wdown = ; if(gawDis[awlastposition[]][awlastposition[]] != )
{
return gawDis[awlastposition[]][awlastposition[]];
}
if(awlastposition[] > )
{
awposition[] = awlastposition[]-;
awposition[] = awlastposition[];
if(wlasthigh > gawMap[awposition[]][awposition[]])
{
wleft = Ski(gawMap[awposition[]][awposition[]], awposition) + ;
}
}
if(awlastposition[] < gawColumn-)
{
awposition[] = awlastposition[]+;
awposition[] = awlastposition[];
if(wlasthigh > gawMap[awposition[]][awposition[]])
{
wright = Ski(gawMap[awposition[]][awposition[]], awposition) + ;
}
}
if(awlastposition[] > )
{
awposition[] = awlastposition[]-;
awposition[] = awlastposition[];
if(wlasthigh > gawMap[awposition[]][awposition[]])
{
wup = Ski(gawMap[awposition[]][awposition[]], awposition) + ;
}
}
if(awlastposition[] < gawRow-)
{
awposition[] = awlastposition[]+;
awposition[] = awlastposition[];
if(wlasthigh > gawMap[awposition[]][awposition[]])
{
wdown = Ski(gawMap[awposition[]][awposition[]], awposition) + ;
}
}
wleft = max(wleft, wright);
wup = max(wup, wdown);
return gawDis[awlastposition[]][awlastposition[]] = max(wleft, wup);
} int main(void)
{
int i = ;
int j = ;
scanf("%d %d", &gawRow, &gawColumn); for(i=; i<gawRow; i++)
{
for(j=; j<gawColumn; j++)
{
scanf("%d", &gawMap[i][j]);
}
} int awposition[] = {};
for(i=; i<gawRow; i++)
{
for(j=; j<gawColumn; j++)
{
awposition[] = j;
awposition[] = i;
Ski(gawMap[awposition[]][awposition[]], awposition);
}
} int wLen = ;
for(i=; i<gawRow; i++)
{
for(j=; j<gawColumn; j++)
{
if(wLen < gawDis[i][j]) wLen = gawDis[i][j];
}
}
printf("%d\n", wLen); return ;
}
北大poj-1088的更多相关文章
- 北大POJ题库使用指南
原文地址:北大POJ题库使用指南 北大ACM题分类主流算法: 1.搜索 //回溯 2.DP(动态规划)//记忆化搜索 3.贪心 4.图论 //最短路径.最小生成树.网络流 5.数论 //组合数学(排列 ...
- POJ 1088 滑雪(记忆化搜索)
滑雪 Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 92384 Accepted: 34948 Description ...
- 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 一道中文题,这道题如果不限时的话,是个简单的搜索,但限时的话,就要用记忆化搜索 所谓记忆化搜索就是对每一次搜索的结果进行记录,然后之后的如 ...
- POJ 1088 滑雪 (记忆化搜索)
题目链接:http://poj.org/problem?id=1088 题意很好懂,就是让你求一个最长下降路线的长度. dp[i][j]记录的是i j这个位置的最优的长度,然后转移方程是dp[i][j ...
- POJ 1088 滑雪 -- 动态规划
题目地址:http://poj.org/problem?id=1088 Description Michael喜欢滑雪百这并不奇怪, 因为滑雪的确很刺激.可是为了获得速度,滑的区域必须向下倾斜,而且当 ...
- 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 感觉对深搜还不太熟练,所以练习一下,类似于连连看的那题,注意的是所求的是最大达长度,并不是从最大的或者最小的点出发得到的就是最长的路 ...
- POJ 1088 滑雪 【记忆化搜索经典】
题目链接:http://poj.org/problem?id=1088 滑雪 Time Limit: 1000MS Memory Limit: 65536K Total Submissions: ...
随机推荐
- 二、快速起步(Mysql镜像)
1.登录镜像站点 docker login daocloud.io 用户名 密码 邮箱 1.1 拉取镜像 docker pull [option] name:[tag] 例如 docker pull ...
- keytool的使用
1. 创建数字证书 keytool -genkey -v -alias scent -dname "CN=John,OU=MNG,O=Corp,L=Hangzhou,ST=Zhejiang, ...
- 使用异步js解决模态窗口切换的办法
核心代码 js ="setTimeout(function(){document.getElementsByTagName('Button')[3].click()},100);" ...
- iptables交互配置shell脚本
#!/bin/bash while true do clear echo "———————-menu————————" echo -e "\033[49;32;1m(1) ...
- sql2008 表名为全数字时查询报错
今天遇到个很奇葩的问题,在写一个应用程序时需要查询表的数据,但是表名是全数字的,直接查询会报错,于是想到给111的表名加一对中括号:即——>select * from [111] 刚开始还是报错 ...
- assigning to 'id<UIGestureRecognizerDelegate> _Nullable' from incompatible
tip:参考 http://stackoverflow.com/questions/9861538/assigning-to-iddelegate-from-incompatible-type-vie ...
- HMI开发与控件
=>控件是什么概念? 百度曰,控件是对数据和方法的封装.控件可以有自己的属性和方法.属性是控件数据的简单访问者. 对于HMI开发来说,使用控件可以快速获取到用户的交互(包括按下.释放.点击.拖动 ...
- centos7 Nexus maven私有仓库
cd /home wget http://www.sonatype.org/downloads/nexus-latest-bundle.tar.gz mkdir nexus tar zxvf nexu ...
- linux top命令
top命令参数 -h:help表示显示帮助的意思 -v:version显示版本的意思,和-h的功能一样 -u:user显示指定用户的进程,例如:top -u root -p:pid显示指定进程,例如: ...
- Html_Img元素 设置图片与其他元素横排高度一致
<img id="numAdd" src="~/Images/jia.jpg" style="width:30px;height:30px;ve ...