Code[VS] 2152 滑雪题解
Code[VS] 2152 滑雪题解
trs喜欢滑雪。他来到了一个滑雪场,这个滑雪场是一个矩形,为了简便,我们用r行c列的矩阵来表示每块地形。为了得到更快的速度,滑行的路线必须向下倾斜。
例如样例中的那个矩形,可以从某个点滑向上下左右四个相邻的点之一。例如24-17-16-1,其实25-24-23…3-2-1更长,事实上这是最长的一条。
输入文件
第1行: 两个数字r,c(1<=r,c<=100),表示矩阵的行列。
第2..r+1行:每行c个数,表示这个矩阵。
输出文件
仅一行: 输出1个整数,表示可以滑行的最大长度。
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
25
1s
————————————————————————————分割线————————————————————————————
//Code By DrSHHHS #include "bits/stdc++.h" using namespace std ; const int maxN = ;
const int INF = ; struct Slide {int x , y , val ;}; Slide arr[maxN] ;
int f[maxN] ; bool cmp ( Slide a , Slide b ) { return a.val > b.val ;}
int Abs ( int x ) { return x>?x:-x ;}
int Max ( int a , int b ){ return a>b?a:b ; } bool Judge ( int p1 , int p2 ) {//判断两座山是否相邻且严格下降
if (( Abs ( arr[p1].x - arr[p2].x) + Abs ( arr[p1].y - arr[p2].y) )== && arr[p2].val > arr[p1].val) return true ;
else return false ;
} int main ( ) {
int N , M , tmp , K = ,ans = -INF ; scanf("%d%d",&N ,&M ) ;
for ( int i= ; i<=N ; ++i ){
for ( int j= ; j<=M ; ++j ){
K++;
scanf( "%d" , &tmp ) ;//将二维数组读入一个一维数组arr中
arr[K].val = tmp ;
arr[K].x = i ;arr[K].y = j ;//记录原始坐标
}
} sort ( arr+ , arr+K+ , cmp ) ;//排序 f[] = ; for ( int i= ; i<=K ; ++i ){//最长下降子序列
for ( int j= ; j<=i- ; ++j ) {
if ( Judge ( i , j ) ){//判断相邻切严格下降
f[i] = Max ( f[i] , f[j] ) ;
}
}
f[i] = f[i] + ;
} for ( int i= ; i<=K ; ++i ){//找最大值
ans = Max ( f[i] , ans ) ;
} printf ( "%d" , ans ) ; return ;
}
#include "bits/stdc++.h" using namespace std ;
const int maxN = ; int h[maxN][maxN] , f[maxN][maxN] ;
int n, m, ans = ; int DFS(int x, int y)
{
if( f[x][y] )return f[x][y];
f[x][y] = ;
if(x > && h[x][y] < h[x - ][y])f[x][y] = max(f[x][y], DFS(x - , y) + );
if(y > && h[x][y] < h[x][y - ])f[x][y] = max(f[x][y], DFS(x, y - ) + );
if(x < n && h[x][y] < h[x + ][y])f[x][y] = max(f[x][y], DFS(x + , y) + );
if(y < m && h[x][y] < h[x][y + ])f[x][y] = max(f[x][y], DFS(x, y + ) + );
ans = max(ans, f[x][y]);
return f[x][y];
}
int main()
{
scanf("%d%d", &n, &m);
for ( int i = ; i <= n ; i++ )
for ( int j = ; j <= m ; j++ )
scanf( "%d" , &h[i][j] ) ;
for(int i = ; i <= n ; i++ )
for(int j = ; j <= m ; j++ )
f[i][j] = DFS( i , j ) ;
printf("%d", ans); return ;
}
2016-09-14 15:45:58
(完)
Code[VS] 2152 滑雪题解的更多相关文章
- codevs 2152 滑雪
2152 滑雪 时间限制: 1 s 空间限制: 32000 KB 题目等级 : 黄金 Gold 题解 题目描述 Description trs喜欢滑雪.他来到了一个滑雪场,这个滑雪场 ...
- codevs——2152 滑雪
2152 滑雪 时间限制: 1 s 空间限制: 32000 KB 题目等级 : 黄金 Gold 题解 题目描述 Description trs喜欢滑雪.他来到了一个滑雪场,这个滑雪场 ...
- Code[VS] 1022 覆盖 题解
Code[VS] 1022 覆盖 题解 Hungary Algorithm 题目传送门:Code[VS] 1022 题目描述 Description 有一个N×M的单位方格中,其中有些方格是水塘,其 ...
- Code[VS]1690 开关灯 题解
Code[VS]1690 开关灯 题解 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description: YYX家门前 ...
- Code[VS] 2370 LCA 题解
Code[VS] 2370 小机房的树 题解 RMQ 树链剖分 题目描述 Description 小机房有棵焕狗种的树,树上有N个节点,节点标号为0到N-1,有两只虫子名叫飘狗和大吉狗,分居在两个不同 ...
- 洛谷[SHOI2002]滑雪题解
什么破题啊 简直就是浪费我时间! 我每天还被我xf定目标了不知道嘛! 题目 朴素的搜索只能得90分 #include <cstdio> #include <iostream> ...
- 洛谷P1434滑雪题解及记忆化搜索的基本步骤
题目 滑雪是一道dp及记忆化搜索的经典题目. 所谓记忆化搜索便是在搜索的过程中边记录边搜索的一个算法. 当下次搜到这里时,便直接使用. 而且记忆化搜索一定要满足无后效性,为什么呢,因为如果不满足无后效 ...
- Codeforces 965E Short Code 启发式合并 (看题解)
Short Code 我的想法是建出字典树, 然后让后面节点最多的点优先向上移到不能移为止, 然后gg. 正确做法是对于当前的节点如果没有被占, 那么从它的子树中选出一个深度最大的点换到当前位置. 用 ...
- CODE FESTIVAL 2017 Final题解
传送门 \(A\) 咕咕 const int N=55; const char to[]={"AKIHABARA"}; char s[N];int n; int main(){ s ...
随机推荐
- App 开发:Hybrid 架构下的 HTML5 应用加速方案
在移动 App 开发领域,主流的开发模式可分为 Native.Hybrid.WebApp 三种方式.然而 2013 年,纯 WebApp 开发模式的发展受到一定挫折,以 Facebook 为代表的独立 ...
- js 上传文件后缀名的判断 var flag=false;应用
js 上传文件后缀名的判断 var flag=false;应用 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional// ...
- android 入门-android自定义控件
第一种:继承View 实现自己的属性 <com.cc.imagewithmarkersample.MyView android:id="@+id/myviewid" andr ...
- Uncaught ReferenceError: console is not defined
今天写javascript代码遇到了这个极其神奇的问题,居然报错说内置的console不存在,而且后来我换成了alert也不行.照例说这些都是js代码内置的东西不应该出现这种错误.不过百度之发现貌似没 ...
- 咱就入个门之NHibernate映射文件配置(二)
上一篇主要介绍了NHibernate映射文件的基础配置,这篇我们介绍下NHibernate的一对多及多对一配置(文中我直接使用双向关联,即一和多两端都配置,开发中可以只使用一端),同时略带介绍下NHi ...
- 在ubuntu中安装jdk
安装环境 操作系统:ubuntu 14.04.1 server amd64 下载jdk wget http://download.oracle.com/otn-pub/java/jdk/7u67-b0 ...
- 利用Aspose.Word控件和Aspose.Cell控件,实现Word文档和Excel文档的模板化导出
我们知道,一般都导出的Word文档或者Excel文档,基本上分为两类,一类是动态生成全部文档的内容方式,一种是基于固定模板化的内容输出,后者在很多场合用的比较多,这也是企业报表规范化的一个体现. 我的 ...
- 使用while代替for循环的几个习题
1:兔子问题 2:100以内质数的和 3:单位给发了一张150元购物卡,拿着到超市买三类洗化用品.洗发水15元,香皂2元,牙刷5元.求刚好花完150元,有多少种买法,没种买法都是各买几样? 总结:wh ...
- ASP.Net MVC开发基础学习笔记(3):Razor视图引擎、控制器与路由机制学习
一.天降神器“剃须刀” — Razor视图引擎 1.1 千呼万唤始出来的MVC3.0 在MVC3.0版本的时候,微软终于引入了第二种模板引擎:Razor.在这之前,我们一直在使用WebForm时代沿留 ...
- Java会出现"unreachable code"错误的几个例子
public class exam { static int num=5; static int m1(){ try{ num=6; throw new NullPointerException(); ...