skiing

时间限制:3000 ms  |  内存限制:65535 KB
难度:5
描写叙述
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更长。其实,这是最长的一条。

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

后面是下一组数据;
输出
输出最长区域的长度。

算法分析:

一看本题就感觉这不是才看过的单调递减子序列问题么。但这个难点在于数据并非线性的,每一步都有四个方向可走。于是乎。,深搜解此题必须是手到擒来啊。。注意中间的剪枝问题。利用记忆话数组去除反复的计算类似于递归型DP,以下看一个来自网上的深搜代码:

#include<stdio.h>
#include<string.h>
int a[101][101],visit[101][101];
int dx[4]={0,0,1,-1};
int dy[4]={1,-1,0,0};
int s,t,max,r,c;
int bfs(int x,int y)
{
if(visit[x][y]>1)//**剪枝。不剪枝应该是TLE的,測试数据有点弱,只是就算没TLE。加了剪枝的时间优化了不少*//
{
return visit[x][y];//**假设曾经搜索过这点,就直接返回搜索的这点。不用再进行搜索**//
}
for(int k=0;k<4;k++)
{
s=x+dx[k];
t=y+dy[k];
if(s>=0 && s<r && t>=0 && t<c && a[x][y]<a[s][t])//**搜索的范围。 DP看作单调递增数列**//
{
max=bfs(s,t);//**动态规划**//
if(visit[x][y]<max+1)
{
visit[x][y]=max+1;
}
}
}
return visit[x][y];//**返回这点能取得的最大值**//
}
int main()
{
int ncases,i,j,ans;
scanf("%d",&ncases);
while(ncases--)
{
ans=-1;
scanf("%d %d",&r,&c);
for(i=0;i<=r-1;i++)
{
for(j=0;j<=c-1;j++)
{
scanf("%d",&a[i][j]);
visit[i][j]=1;
}
}
for(i=0;i<=r-1;i++)
{
for(j=0;j<=c-1;j++)
{
bfs(i,j);
if(visit[i][j]>ans)
{
ans=visit[i][j];
}
}
}
printf("%d\n",ans);
}
return 0;
}

注意,这里为了保证以随意起点開始搜索,必需要以m*n个起点进行向下深搜,这也自然使得时间复杂度提升了。于是乎我选择的是人人为我型动归,以其它四个方向的值来不断更新当前点的值,然后不断进行递推,但问题来了。为了使得每次递归都以当前最低位置開始,那么每一次递推的起点怎么确定呢???这里我的确被坑了一下,想了各种不同的方案,比方,增设一维数组来保存map,j进行排序。但怎么返回坐标呢。之后我有通过双循环不断产生去除上一个最低位置后的最低位置,但这不是比深搜还有麻烦,最后无奈之下,结构体走起。。。问题就直接攻克了

#include<iostream>
#include<algorithm>
using namespace std;
int map[101][101];
int d[101][101];
struct node{
int x,y;
int value;
}tmap[10001];
int K;
int dir[2][4]={{1,0,-1,0},{0,1,0,-1}};
int max(int a,int b)
{return a>b?a:b;}
int comp(node a,node b)
{
return a.value<b.value;
}
int dp(int m,int n)
{
int i,j,k,x,y,ans=0,p;
for(p=0;p<K;p++)
{
i=tmap[p].x;
j=tmap[p].y;
for(k=0;k<4;k++)
{
x=i+dir[0][k];
y=j+dir[1][k];
if(x>=1&&x<=m&&y>=1&&y<=n&&map[x][y]<map[i][j])
d[i][j]=max(d[i][j],d[x][y]+1);
ans=ans>d[i][j]? ans:d[i][j];
}
}
return ans;
}
int main()
{
int N,m,n,i,j;
cin>>N;
while(N--)
{
K=0;
cin>>m>>n;
for(i=1;i<=m;i++)
for(j=1;j<=n;j++)
{
cin>>map[i][j];
d[i][j]=1;
tmap[K].x=i;
tmap[K].y=j;
tmap[K++].value=map[i][j];
}
sort(tmap,tmap+K,comp);
cout<<dp(m,n)<<endl;
}
return 0;
}

NYOJ 10 skiing (深搜和动归)的更多相关文章

  1. nyoj 10 skiing 搜索+动归

    整整两天了,都打不开网页,是不是我提交的次数太多了? nyoj 10: #include<stdio.h> #include<string.h> ][],b[][]; int ...

  2. nyoj 10——skiing————————【记忆化搜索】

    skiing 时间限制:3000 ms  |  内存限制:65535 KB 难度:5   描述 Michael喜欢滑雪百这并不奇怪, 因为滑雪的确很刺激.可是为了获得速度,滑的区域必须向下倾斜,而且当 ...

  3. nyoj 10 skiing(记忆化搜索)

    skiing 时间限制:3000 ms  |  内存限制:65535 KB 难度:5   描述 Michael喜欢滑雪百这并不奇怪, 因为滑雪的确很刺激.可是为了获得速度,滑的区域必须向下倾斜,而且当 ...

  4. NYOJ 10 skiing动态规划心得

    这道题目,拿到手中,首先想到的是搜索,但是,后来想了想搜索不知道从哪搜起,就看了一下分类,一看属于动态规划类的,因为以前没有接触过动态规划,所以在网上搜了一下动态规划的思想,看过之后也有想到将它们到周 ...

  5. NYOJ 10 skiing(好题)

    skiing 时间限制:3000 ms  |  内存限制:65535 KB 难度:5   描述 Michael喜欢滑雪百这并不奇怪, 因为滑雪的确很刺激.可是为了获得速度,滑的区域必须向下倾斜,而且当 ...

  6. nyoj 10 skiing (DFS)

    skiing 时间限制:3000 ms  |  内存限制:65535 KB 难度:5   描述 Michael喜欢滑雪百这并不奇怪, 因为滑雪的确很刺激.可是为了获得速度,滑的区域必须向下倾斜,而且当 ...

  7. NYoj 部分和问题(深搜经典)

    题目链接: http://acm.nyist.edu.cn/JudgeOnline/problem.php?pid=1058 #include <stdio.h> ], vis[], co ...

  8. 2016弱校联盟十一专场10.3---Similarity of Subtrees(深搜+hash、映射)

    题目链接 https://acm.bnu.edu.cn/v3/problem_show.php?pid=52310 problem description Define the depth of a ...

  9. 2016弱校联盟十一专场10.2---Around the World(深搜+组合数、逆元)

    题目链接 https://acm.bnu.edu.cn/v3/problem_show.php?pid=52305 problem  description In ICPCCamp, there ar ...

随机推荐

  1. 计算gcd Exercise07_14

    import java.util.Scanner; /** * @author 冰樱梦 * 时间:2018年下半年 * 题目:计算gcd * */ public class Exercise07_14 ...

  2. Codeforces Round #114 (Div. 1) D. Wizards and Roads 笛卡尔树+树贪心+阅读题

    D. Wizards and Roads 题目连接: http://www.codeforces.com/contest/167/problem/D Description In some count ...

  3. zk常见面试题

    一个客户端修改了某个节点的数据,其它客户端能够马上获取到这个最新数据吗 ZooKeeper不能确保任何客户端能够获取(即Read Request)到一样的数据,除非客户端自己要求:方法是客户端在获取数 ...

  4. VMware 8安装Mac OS X 10.7

    (Windows 7 X64环境下,VMware 8.0正式版)虚拟机首尝MAC OS X 10.7 Lion系统成功,特将此好消息分享.2年了,终于我也装上了Mac,我也成功的尝到了苹果味道,看着那 ...

  5. WinCE5.0开发环境的建立

    目前WinCE5.0的开发工具主要有以下几种:Platform Builder5.0.EVC4.0+SP4.Visual Studio2005.其中Platform Builder主要用于定制WinC ...

  6. Atom 有什么优秀插件?

    蓝色 ,主业三流青春校园小说作家兼反差萌段子手… 韦易笑等 130 人赞同 若是C / C++的话,我推荐ATOM的这几个插件主要用于代码补全,实时语法检测,以及代码格式调整,其实就是Clang的那一 ...

  7. Objective-C:KVO机制

    KVO:key value observer 键值对的观察者   功能:给对象属性添加观察者,用来时时监测对象属性值的改变,一旦属性值发生了改变,观察者就做出相应的反应,提醒用户.在应用中,针对MVC ...

  8. centos7搭建svn服务器并支持http方式访问

    因为公司其他人员需要,需要在服务器上搭建svn服务,途中遇到不少问题,做下记录 第一步,安装svn 默认centos7是已经安装了svn即subversion 检查是否安装 rpm -qa subve ...

  9. gridcontrol表头设置

    点击Run Disigner进入设计界面,设置颜色字体等信息在Appearance分支下面,设置行为功能,显示区域等在Options分支下面.

  10. glsl水包含倒影的实现(rtt) 【转】

    http://blog.sina.com.cn/s/blog_78ea87380101eixi.html 此文实现一个简单地水面倒影效果,通过rtt相机 获取倒影纹理, 水的基本实现方法(参考前一博文 ...