A Famous City

题目大意 给出正视图  每一列为楼的高度 最少有几座楼

坑点 楼高度可以为0 代表没有楼

贡献了两发RE 原因 if(!s.empty()&&tem){s.push(tem); continue;}并不能筛去 空栈且 tem为0的情况

改为 if(!s.empty()){if(tem) s.push(tem); continue;} 后AC

题目思路 维护一个单调递增的栈  假如新加入的楼高度小于top元素 那我们知道top元素一定是单独的一栋楼 我们就pop掉 ans++

如果 等于top 那么可以认为 这两个是一栋楼(最少)

如果大于pop  就添加下一个

操作结束后 剩余在栈内的元素 每一个必然是独立的一栋楼

楼的高度0 一定要特判

对栈进行top pop 这些操作前一定要判empty啊

代码如下

  1. #include<cstdio>
  2. #include<map>
  3. //#include<bits/stdc++.h>
  4. #include<vector>
  5. #include<stack>
  6. #include<iostream>
  7. #include<algorithm>
  8. #include<cstring>
  9. #include<cmath>
  10. #include<queue>
  11. #include<cstdlib>
  12. #include<climits>
  13. #define PI acos(-1.0)
  14. #define INF 0x3f3f3f3f
  15. using namespace std;
  16. typedef long long ll;
  17. typedef __int64 int64;
  18. const ll mood=1e9+;
  19. const int64 Mod=;
  20. const double eps=1e-;
  21. const int N=2e7+;
  22. const int MAXN=1e5+;
  23. inline void rl(ll&num){
  24. num=;ll f=;char ch=getchar();
  25. while(ch<''||ch>''){if(ch=='-')f=-;ch=getchar();}
  26. while(ch>=''&&ch<='')num=num*+ch-'',ch=getchar();
  27. num*=f;
  28. }
  29. inline void ri(int &num){
  30. num=;int f=;char ch=getchar();
  31. while(ch<''||ch>''){if(ch=='-')f=-;ch=getchar();}
  32. while(ch>=''&&ch<='')num=num*+ch-'',ch=getchar();
  33. num*=f;
  34. }
  35. int getnum()//相邻的个位整数输入 如想分别保存1234 输入连续的1234 a[i]=getnum();就可以实现
  36. {
  37. char ch=getchar();
  38. while((ch<'' || ch>'') && ch!='-')
  39. ch=getchar();
  40. return (ch-'');
  41. }
  42. inline void out(int x){ if(x<) {putchar('-'); x*=-;}if(x>) out(x/); putchar(x%+''); }
  43. int main()
  44. {
  45.  
  46. int n,ci=;
  47. while(scanf("%d",&n)!=EOF)
  48. {
  49. int tem;
  50. ll ans=;
  51. stack<int>s;
  52. for(int i=;i<n;i++)
  53. {
  54. ri(tem);
  55. if(s.empty())
  56. {
  57. if(tem)s.push(tem);
  58. continue;
  59. }
  60. if(s.top()==tem) continue;
  61. if(tem<s.top())
  62. {
  63. while(!s.empty()&&s.top()>tem)
  64. {
  65. s.pop();
  66. ans++;
  67. }
  68. if(!s.empty()&&s.top()==tem) continue;
  69. else{
  70. if(tem)s.push(tem);
  71. }
  72. }
  73. else{
  74. if(tem)s.push(tem);
  75. }
  76. }
  77. printf("Case %d: ",++ci);
  78. ans+=s.size();
  79. cout<<ans<<endl;
  80. }
  81. return ;
  82. }

AC代码

单调栈3_水到极致的题 HDOJ4252的更多相关文章

  1. poj3250(单调栈模板题)

    题目链接:https://vjudge.net/problem/POJ-3250 题意:求序列中每个点右边第一个>=自身的点的下标. 思路:简单介绍单调栈,主要用来求向左/右第一个小于/大于自身 ...

  2. 【单调栈】hdu 6319 杭电多校Problem A. Ascending Rating

    http://acm.hdu.edu.cn/showproblem.php?pid=6319 从后往前更新,维护一个递减单调栈(队列) 最近很多题都是单调栈... #define _CRT_SECUR ...

  3. HDU 5875 H - Function 用单调栈水过了

    http://acm.hdu.edu.cn/showproblem.php?pid=5875 单调栈,预处理to[i]表示第一个比a[i]小的数字,一直跳就可以. 这题是数据水而已. 这里学习下单调栈 ...

  4. BZOJ1113 海报PLA1(单调栈入门题)

    一,自己思考下 1,先自己思考下 N个矩形,排成一排,现在希望用尽量少的海报去cover住它们. 2,不懂. 着实不懂. 3,分析下,最优性问题对吧,然后就每什么想法了.. 虽然肯定和单调栈和单调队列 ...

  5. LeetCode42题,单调栈、构造法、two pointers,这道Hard题的解法这么多?

    本文始发于个人公众号:TechFlow,原创不易,求个关注 今天是LeetCode专题的第23篇文章. 今天来看一道很有意思的题,它的难度是Hard,并且有许多种解法. 首先我们来看题面,说是我们有若 ...

  6. poj2559/hdu1506 单调栈经典题

    我实在是太菜了啊啊啊啊啊 到现在连个单调栈都不会啊啊啊 写个经典题 #include<cstdio> #include<algorithm> #include<cstri ...

  7. [Usaco2006 Mar]Mooo 奶牛的歌声(单调栈裸题)

    1657: [Usaco2006 Mar]Mooo 奶牛的歌声 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 961  Solved: 679[Submi ...

  8. 单调栈2 POJ3250 类似校内选拔I题

    这个题再次证明了单调栈的力量 简单 单调栈 类似上次校内选拔消砖块 一堆牛面朝右排 给出从左到右的 问每个牛的能看到前面牛发型的个数之和 //re原因 因为在执行pop的时候没有判断empty 程序崩 ...

  9. [校内自测 NOIP模拟题] chenzeyu97要请客(单调栈)

    题目描述 chenzeyu97的家可以看成是一个n*m的矩阵,每块区域都有独一无二的海拔高度h(h>0)!其最大值为n*m. 现在他要选择一个子矩阵摆放一张桌子,在他眼里,这样摆放桌子的美观度为 ...

随机推荐

  1. 1、css选择器

    一.CSS rgb颜色对照表:https://www.114la.com/other/rgb.htm 1.在标签上设置style属性 <!DOCTYPE html> <html la ...

  2. bat批处理教程

    批处理的本质,是一堆DOS命令按一定顺序排列而形成的集合 1.ping sz.tencent.com > a.txt 把前面信息放到a.txt中 ping sz.tencent.com > ...

  3. 重温sql 设计的基本三大范式

    第一范式:确保每列的原子性. 如果每列(或者每个属性)都是不可再分的最小数据单元(也称为最小的原子单元),则满足第一范式. 例如:顾客表(姓名.编号.地址.……)其中"地址"列还可 ...

  4. 洛谷 - P2568 - GCD - 欧拉函数

    https://www.luogu.org/problemnew/show/P2568 统计n以内gcd为质数的数的个数. 求 \(\sum\limits_p \sum\limits_{i=1}^{n ...

  5. Shader第十三讲 Alpha混合

    http://blog.sina.com.cn/s/blog_471132920101d8z5.html Alpha Blending,中文译作Alpha混合Blending就是控制透明的.处于光栅化 ...

  6. 51nod1076(tarjan)

    题目链接:http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1076 题意:中文题诶- 思路:先用tarjan找出所有桥,再用 ...

  7. [Xcode 实际操作]一、博主领进门-(3)使用资源文件夹(Assets.xcassets)导入并管理图片素材

    目录:[Swift]Xcode实际操作 本文将演示如何使用资源文件夹(Assets.xcassets)导入并管理图片素材. [Assets.xcassets]资源文件夹可以方便的进行图片的管理, 在读 ...

  8. IT兄弟连 JavaWeb教程 Cookie和Session应用结合使用

    一般对于不要求安全的非敏感数据,建议存储在Cookie中! 对于敏感的数据,占用空间较小的,建议存储在Session中! 对于敏感的,较大的数据,存数据库!

  9. 转 java ClassLoader

    http://blog.csdn.net/xyang81/article/details/7292380 http://www.ibm.com/developerworks/cn/java/j-lo- ...

  10. Spring Boot后端+Vue前端+微信小程序,完整的开源解决方案!

    项目简介 一个小商场系统,包括: 后端:Spring Boot 管理员前端:Vue 用户前端:微信小程序 功能介绍 1.小商城 首页 专题列表.专题详情 分类列表.分类详情 品牌列表.品牌详情 新品首 ...