题目

这题挺简单的,没必要用数组

【分析】

需要判断的是低洼地的数量

通过对题目中图进行分析,显然可以发现低洼地的定义:

若数组中存在一个数值相同的连续区间,这个区间端点外相邻两点的数值都大于该区间的数值,则该区间为低洼地

有的朋友也许会觉得这个定义很麻烦,但有时候,定义是必须的

比如这题,如果单纯地将低洼地理解为中间都比周围低,那么对于这组数据:

3 2 1 2 1 2 3

就会被视为一个低洼地,而不是两个了

我们回来。可以发现,对于 一个数值相同的区间 显得有些无趣,毕竟我们不需要知道区间长度,只需要这个区间的数值

所以,对于相同的相邻读入,可以直接存为一个

这样,我们对于我们储存的数据,低洼地的定义就不同了:

若数组中存在一个数,它既小于它的前一个数,又小于它后一个数,则这个数是低洼地

我们需要的是低洼地的数量,所以一边读入,一边处理即可

具体细节可以参考本蒟蒻的代码

还有一个细节,第一个点和最后一个点一定不是低洼地,可以考虑初始化为上坡,这个可以在本蒟蒻的代码中体现


【代码】

那本蒟蒻就放 我码风极丑的 代码了

#include<cstdio>
using namespace std;
int main(){
int d_T,d_F=-2,d_M=-1,d_L,d_Cnt=0;
/*
d_T:数据组数
d_F:当前数的前一个数
d_M:当前数
d_L:当前数的后一个数
d_Cnt:低洼地的数量
因为高度保证>=0,初始化为(-2),(-1) 能保证一定是上坡
*/
scanf("%d",&d_T);
while(d_T--){
scanf("%d",&d_L);
if(d_L==d_M) continue;
//数值相同,不需要新存
if(d_M<d_F&&d_M<d_L) d_Cnt++;
//判断是否是低洼地,是的话记录
d_F=d_M;
d_M=d_L;
//更新
}
printf("%d",d_Cnt);
return 0;
}

想学读入优化和输出优化的朋友,这里也给出代码,但是对这题没有什么影响

#include<cstdio>
using namespace std;
#define f(a,b,c,d) for(register int a=b,c=d;a<=c;a++)
#define g(a,b,c,d) for(register int a=b,c=d;a>=c;a--)
typedef int i32;
typedef unsigned int u32;
typedef long long int i64;
typedef unsigned long long int u64;
namespace IO{
//#define LOCAL
#ifdef LOCAL
inline char gc() { return getchar(); }
#else
inline char gc(){
static char s[1<<20|1]={0},*p1=s,*p2=s;
return (p1==p2)&&(p2=(p1=s)+fread(s,1,1<<20,stdin),p1==p2)?EOF:*(p1++);
}
#endif
inline i64 read(){
register i64 ans=0;register char c=gc();register bool neg=0;
while(c<48||c>57) neg^=!(c^45),c=gc();
while(c>=48&&c<=57) ans=(ans<<3)+(ans<<1)+(c^48),c=gc();
return neg?-ans:ans;
}
char Output_Ans[1<<20|1],*Output_Cur=Output_Ans;
inline void output() { Output_Cur-=fwrite(Output_Ans,1,Output_Cur-Output_Ans,stdout); }
inline void print(char c){
if(Output_Cur-Output_Ans+1>>20) output();
*(Output_Cur++)=c;
}
inline void print(i64 ans){
register char buf[20]={0};
if(Output_Cur-Output_Ans+sprintf(buf,"%lld",ans)>>20) output();
Output_Cur+=sprintf(Output_Cur,"%lld",ans);
}
inline void print(i32 ans) { print(0ll|ans); }
inline void print(u64 ans){
register char buf[20]={0};
if(Output_Cur-Output_Ans+sprintf(buf,"%llu",ans)>>20) output();
Output_Cur+=sprintf(Output_Cur,"%llu",ans);
}
inline void print(u32 ans) { print(0ull|ans); }
}
using namespace IO;
int main(){
register i32 d_T=read(),d_F=-2,d_M=-1,d_L,d_Cnt=0;
while(d_T--){
d_L=read();
if(d_L==d_M) continue;
if(d_M<d_F&&d_M<d_L) d_Cnt++;
d_F=d_M;
d_M=d_L;
}
print(d_Cnt);
output();
return 0;
}

最后安利一下 本蒟蒻的博客

题解 P1317 【低洼地】的更多相关文章

  1. [洛谷P1317]低洼地

    题目大意:一组数,分别表示地平线的高度变化.高度值为整数,相邻高度用直线连接.找出并统计有多少个可能积水的低洼地?(首尾都为0) 题解:求出其中都多少个不严格下降子段和不严格上升子段所夹的位置,即为答 ...

  2. 强大的unique

    强大的unique 两道红题为例眼熟一下unique P1138 第k小整数 题解 这里用到了STL的去重函数哦 unique 首先你有一个待处理的数组 a[n] 一定要先排序鸭  sort( a+1 ...

  3. 2016 华南师大ACM校赛 SCNUCPC 非官方题解

    我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...

  4. noip2016十连测题解

    以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...

  5. BZOJ-2561-最小生成树 题解(最小割)

    2561: 最小生成树(题解) Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1628  Solved: 786 传送门:http://www.lyd ...

  6. Codeforces Round #353 (Div. 2) ABCDE 题解 python

    Problems     # Name     A Infinite Sequence standard input/output 1 s, 256 MB    x3509 B Restoring P ...

  7. 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解

    题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...

  8. 2016ACM青岛区域赛题解

    A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Jav ...

  9. poj1399 hoj1037 Direct Visibility 题解 (宽搜)

    http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...

随机推荐

  1. 吴裕雄 Bootstrap 前端框架开发——Bootstrap 字体图标(Glyphicons):glyphicon glyphicon-backward

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name ...

  2. JuJu团队11月25号工作汇报

    JuJu团队11月25号工作汇报 JuJu   Scrum 团队成员 今日工作 剩余任务 困难 于达 实现随机采样函数,进行onehot处理 预处理数据集,将数据集转为矩阵读入 数据集预处理比想象中麻 ...

  3. python基础数据类型--集合(set)

    python基础数据类型--集合(set) 集合是一个数学概念由一个或多个确定的元素所构成的整体叫做集合 集合中的三个特征 1.确定性(元素必须死可hash) 2.互异性(去重) 3.无序性(集合中的 ...

  4. redis学习(三)

    一.Redis 数据类型 Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合). 二.Redis 命令 1 ...

  5. Tomcat添加SSL安全认证

    环境 Tomcat7.阿里SSL证书 server.xml <Connector port="443" protocol="org.apache.coyote.ht ...

  6. 解决dispatch 后在当前页面不能获取最新的this.props中的数据

    因为dispatch为异步方法  .解决这个问题方法很多  出去添加定时器这种不是很优雅的方法  我们可以用 componentWillReceiveProps(nextProps) 这个生命周期  ...

  7. 163-PHP 文本替换函数str_replace(四)

    <?php $str='Hello world!'; //定义源字符串 $search=array('o','l','w'); //定义将被替换的字符数组 $replace=array('1', ...

  8. ubuntu18.04.2 hadoop3.1.2+zookeeper3.5.5高可用完全分布式集群搭建

    ubuntu18.04.2 hadoop3.1.2+zookeeper3.5.5高可用完全分布式集群搭建 集群规划: hostname NameNode DataNode JournalNode Re ...

  9. Origin中使用CopyPage复制图片到Word后比例失调解决办法

    Origin画图的优势很多,其图形美观易于操作.对我而言,Origin最大的优点就是与Word兼容,在Origin操作界面空白处直接使用右键CopyPage命令,然后在Word中使用粘贴命令即可插入图 ...

  10. ProxyPass与ProxyPassReverse及ProxyPassMatch的概述

    转载自:https://blog.csdn.net/xiaokui_wingfly/article/details/51481653 apache中的mod_proxy模块主要作用就是进行url的转发 ...