滑雪
Time Limit: 1000MS   Memory Limit: 65536K
Total Submissions: 88484   Accepted: 33177

Description

Michael 喜欢滑雪百这并不奇怪, 因为滑雪的确很刺激。可是为了获得速度,滑的区域必须向下倾斜,而且当你滑到坡底,你不得不再次走上坡或者等待升降机来载你。Michael想知道载一个 区域中最长底滑坡。区域由一个二维数组给出。数组的每个数字代表点的高度。下面是一个例子

 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

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

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的更多相关文章

  1. 北大POJ题库使用指南

    原文地址:北大POJ题库使用指南 北大ACM题分类主流算法: 1.搜索 //回溯 2.DP(动态规划)//记忆化搜索 3.贪心 4.图论 //最短路径.最小生成树.网络流 5.数论 //组合数学(排列 ...

  2. POJ 1088 滑雪(记忆化搜索)

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

  3. POJ 1088 滑雪(记忆化搜索+dp)

    POJ 1088 滑雪 Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 107319   Accepted: 40893 De ...

  4. POJ 1088

    http://poj.org/problem?id=1088 一道中文题,这道题如果不限时的话,是个简单的搜索,但限时的话,就要用记忆化搜索 所谓记忆化搜索就是对每一次搜索的结果进行记录,然后之后的如 ...

  5. POJ 1088 滑雪 (记忆化搜索)

    题目链接:http://poj.org/problem?id=1088 题意很好懂,就是让你求一个最长下降路线的长度. dp[i][j]记录的是i j这个位置的最优的长度,然后转移方程是dp[i][j ...

  6. POJ 1088 滑雪 -- 动态规划

    题目地址:http://poj.org/problem?id=1088 Description Michael喜欢滑雪百这并不奇怪, 因为滑雪的确很刺激.可是为了获得速度,滑的区域必须向下倾斜,而且当 ...

  7. OpenJudge/Poj 1088 滑雪

    1.链接地址: bailian.openjudge.cn/practice/1088 http://poj.org/problem?id=1088 2.题目: 总Time Limit: 1000ms ...

  8. poj 1088 滑雪(区间dp+记忆化搜索)

    题目链接:http://poj.org/problem?id=1088 思路分析: 1>状态定义:状态dp[i][j]表示在位置map[i][j]可以滑雪的最长区域长度: 2>状态转移方程 ...

  9. poj 1088 (dfs+记忆化) 滑雪

    题目;http://poj.org/problem?id=1088 感觉对深搜还不太熟练,所以练习一下,类似于连连看的那题,注意的是所求的是最大达长度,并不是从最大的或者最小的点出发得到的就是最长的路 ...

  10. POJ 1088 滑雪 【记忆化搜索经典】

    题目链接:http://poj.org/problem?id=1088 滑雪 Time Limit: 1000MS   Memory Limit: 65536K Total Submissions:  ...

随机推荐

  1. 创建一个叫做People的类: 属性:姓名、年龄、性别、身高 行为:说话、计算加法、改名 编写能为所有属性赋值的构造方法; (2)创建主类: 创建一个对象:名叫“张三”,性别“男”,年龄18岁,身高1.80; 让该对象调用成员方法: 说出“你好!” 计算23+45的值 将名字改为“李四”

    package com.chuoji; public class People { private String name; private int age; private String sex; ...

  2. 输入参数是NSDate,输出结果是星期几的字符串

    给你一个方法,输入参数是NSDate,输出结果是星期几的字符串.+ (NSString*)weekdayStringFromDate:(NSDate*)inputDate { NSArray *wee ...

  3. iptables交互配置shell脚本

    #!/bin/bash while true do clear echo "———————-menu————————" echo -e "\033[49;32;1m(1) ...

  4. [问题2014A01] 复旦高等代数 I(14级)每周一题(第三教学周)

    [问题2014A01]  试求下列 \(n\) 阶行列式的值: \[ |A|=\begin{vmatrix} 1 & x_1(x_1-a) & x_1^2(x_1-a) & \ ...

  5. React的Transaction浅析

    1.两个示例 示例1 let SonClass = React.createClass({ render: function(){ console.log("render", th ...

  6. JPA入门案例详解(附源码)

    1.新建JavaEE Persistence项目

  7. Export Data from mysql Workbench 6.0

    原文地址:export-data-from-mysql-workbench-6-0 问题描述 I'm trying to export my database, using MySQL Workben ...

  8. socket详解(一)《转》

    在客户/服务器通信模式中, 客户端需要主动创建与服务器连接的 Socket(套接字), 服务器端收到了客户端的连接请求, 也会创建与客户连接的 Socket. Socket可看做是通信连接两端的收发器 ...

  9. NHibernate的使用

    本文档适合初级开发者或者是第一次接触NHibernate框架的朋友,其中NHibernate不是最新的版本,但是一个比较经典的版本 NHibernate 2.1.2,其中用红线标注的部分一定要仔细看, ...

  10. NGUI Atlas, Atlas Type Reference

    在NGUI中,通过创建图集及引用图集,实际使用时指定引用图集而非具体图集本身,可以创建多语言,或高配低配版本资源包. NGUI Atlashttp://www.cnblogs.com/answerwi ...