vijos1011题解
题目:
顺治喜欢滑雪,这并不奇怪,因为滑雪的确很刺激。可是为了获得速度,滑的区域必须向下倾斜,而且当你滑到坡底,你不得不再次走上坡或者等待太监们来载你。顺治想知道载一个区域中最长的滑坡。区域由一个二维数组给出。数组的每个数字代表点的高度。下面是一个例子:
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更长。事实上,这是最长的一条。
思绪连篇啊!这是一道著名的DP题目——滑雪改编。当时,我为了避免后效性,编了一个很弱的DP后,又重复地扫了好几遍,最后还是错了一个点。令我印象深刻的是陈卓凡大神,一个搜索0ms全过!!
站在现在的立场,此题还是挺容易的。当时我怎么也理解不了为什么标程的DP要排序,而现在在思考的时候,就发觉排序是一定要的!我们先从大到小把每个值排一遍(当然同时要记录每个位置的坐标),然后从大到小去对每一个高度操作。对每个高度开一个f[i][j]表示到这个点最多能划的长度。每次操作时,寻找这个点四周的点,如果那个点比当前的点高(由于是从大到小排序的,比他高的点一定在之前已经处理过了),就更新。可能CZF大神的搜索与我的原理一致吧。
代码:
#include<stdio.h>
using namespace std;
longf[501][501],n,m,x[250001],y[250001],a[250001],i,j,ord,data[501][501],xx,yy,ans;
void qsort(int l,int r)
{
int i,j,xx,yy,zz;
if(l>=r) return;
i=l;
j=r;
xx=a[i];yy=x[i];zz=y[i];
while(i!=j)
{
while(a[j]>xx&&j>i) j--;
if(i<j)
{
a[i]=a[j];x[i]=x[j];y[i]=y[j];
i++;
}
while(a[i]<xx&&j>i) i++;
if(i<j)
{
a[j]=a[i];x[j]=x[i];y[j]=y[i];
j--;
}
}
a[i]=xx;x[i]=yy;y[i]=zz;
qsort(l,j-1);
qsort(i+1,r);
}
long max(long a,long b)
{
if (a>b) return a;return b;
}
int main()
{
scanf("%ld %ld",&n,&m);
for (i=1;i<=n;i++)
for (j=1;j<=m;j++)
{
scanf("%ld",&data[i][j]);
f[i][j]=1;
ord=(i-1)*m+j;
a[ord]=data[i][j];
x[ord]=i;y[ord]=j;
}
qsort(1,ord);
for (i=ord;i>0;i--)
{
xx=x[i];yy=y[i];
if(xx>1&&data[xx-1][yy]>data[xx][yy])f[xx][yy]=max(f[xx][yy],f[xx-1][yy]+1);
if(xx<n&&data[xx+1][yy]>data[xx][yy])f[xx][yy]=max(f[xx][yy],f[xx+1][yy]+1);
if(yy>1&&data[xx][yy-1]>data[xx][yy])f[xx][yy]=max(f[xx][yy],f[xx][yy-1]+1);
if(yy<m&&data[xx][yy+1]>data[xx][yy])f[xx][yy]=max(f[xx][yy],f[xx][yy+1]+1);
if (f[xx][yy]>ans)ans=f[xx][yy];
}
printf("%ld",ans);
}
vijos1011题解的更多相关文章
- 2016 华南师大ACM校赛 SCNUCPC 非官方题解
我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...
- noip2016十连测题解
以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...
- BZOJ-2561-最小生成树 题解(最小割)
2561: 最小生成树(题解) Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1628 Solved: 786 传送门:http://www.lyd ...
- Codeforces Round #353 (Div. 2) ABCDE 题解 python
Problems # Name A Infinite Sequence standard input/output 1 s, 256 MB x3509 B Restoring P ...
- 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解
题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...
- 2016ACM青岛区域赛题解
A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Jav ...
- poj1399 hoj1037 Direct Visibility 题解 (宽搜)
http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...
- 网络流n题 题解
学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...
- CF100965C题解..
求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...
随机推荐
- (转ORCLE导入导出命令)
oracle数据库导入导出命令! Oracle数据导入导出imp/exp 功能:Oracle数据导入导出imp/exp就相当与oracle数据还原与备份. 大多情况都可以用Oracle数据导入导出 ...
- 【Spark2.0源码学习】-6.Client启动
Client作为Endpoint的具体实例,下面我们介绍一下Client启动以及OnStart指令后的额外工作 一.脚本概览 下面是一个举例: /opt/jdk1..0_79/bin/jav ...
- Hibernate SQLQuery 原生SQL 查询及返回结果集处理-1
第一篇:官方文档的处理方法,摘自官方 在迁移原先用JDBC/SQL实现的系统,难免需要采用hibernat native sql支持. 1.使用SQLQuery hibernate对原生SQL查询执行 ...
- GRPC在NET上的实践(记录篇)
GRPC是什么? GRPC是一个开源RPC框架,于2015年3月开源,其由Google主要面向移动应用开发并基于HTTP/2协议标准而设计,基于Protobuf 3.0(Protocol Buffer ...
- eclipse hibernate导出数据库实体类
打开eclipse->help->Eclipse Marketplace->查找hibernate->安装如下插件 只要安装其中一个,hibernate tool即可: 安装完 ...
- hdu3715
hdu3715 题意 给出一个递归的伪代码,当 x[a[dep]] + x[b[dep]] != c[dep],就向下递归,给出a,b,c数组的值 问 dep 最大多少.其中 0 <= c[i] ...
- ASP.NET Web API 自定义 HttpParameterBinding
背景 问题的起因是这样的.群里面一个哥们儿发现在使用 ASP.NET WebAPI 时,不能在同一个方法签名中使用多次 FromBodyAttribute 这个 Attribute .正好我也在用 W ...
- 一天搞定CSS:定位position--17
1.定位取值概览 2.相对定位relative <!DOCTYPE html> <html> <head> <meta charset="UTF-8 ...
- Dubbo源码分析系列---扩展点加载
扩展点配置: 约定: 在扩展类的jar包内,放置扩展点配置文件:META-INF/dubbo/接口全限定名,内容为:配置名=扩展实现类全限定名,多个实现类用换行符分隔.(摘自dubbo文档) 示例: ...
- Bash扩展顺序
当进行变量替换.命令替换.数学扩展以及路径扩展时,Bash Shell遵循如下顺序: 1.大括号扩展 $ls f{oo,aa,unble} 2.~扩展 ~cb, ~/doc/working 3.命令参 ...