单调栈3_水到极致的题 HDOJ4252
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啊
代码如下
#include<cstdio> #include<map> //#include<bits/stdc++.h> #include<vector> #include<stack> #include<iostream> #include<algorithm> #include<cstring> #include<cmath> #include<queue> #include<cstdlib> #include<climits> #define PI acos(-1.0) #define INF 0x3f3f3f3f using namespace std; typedef long long ll; typedef __int64 int64; const ll mood=1e9+7; const int64 Mod=998244353; const double eps=1e-9; const int N=2e7+10; const int MAXN=1e5+5; inline void rl(ll&num){num=0;ll f=1;char ch=getchar();while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}while(ch>='0'&&ch<='9')num=num*10+ch-'0',ch=getchar();num*=f; } inline void ri(int &num){num=0;int f=1;char ch=getchar();while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}while(ch>='0'&&ch<='9')num=num*10+ch-'0',ch=getchar();num*=f; } int getnum()//相邻的个位整数输入 如想分别保存1234 输入连续的1234 a[i]=getnum();就可以实现 {char ch=getchar();while((ch<'0' || ch>'9') && ch!='-')ch=getchar();return (ch-'0'); } inline void out(int x){ if(x<0) {putchar('-'); x*=-1;}if(x>9) out(x/10); putchar(x%10+'0'); } int main() {int n,ci=0;while(scanf("%d",&n)!=EOF){int tem;ll ans=0;stack<int>s;for(int i=0;i<n;i++){ri(tem);if(s.empty()){if(tem)s.push(tem);continue;}if(s.top()==tem) continue;if(tem<s.top()){while(!s.empty()&&s.top()>tem){s.pop();ans++;}if(!s.empty()&&s.top()==tem) continue;else{if(tem)s.push(tem);}}else{if(tem)s.push(tem);}}printf("Case %d: ",++ci);ans+=s.size();cout<<ans<<endl;}return 0; }
AC代码
转载于:https://www.cnblogs.com/Geek-xiyang/p/5444885.html
单调栈3_水到极致的题 HDOJ4252相关推荐
- *【牛客 - 318B】签到题(单调栈,水题)
题干: 众所周知,IG是英雄联盟S8世界总决赛冠军,夺冠之夜,数亿人为之欢呼! 赛后某百分百胜率退役ADC选手的某表情包意外走红,某苟会长看到此表情包也想模仿. 于是有n个友爱的萌新决定每人都送会长一 ...
- [力扣刷题总结](栈和单调栈篇)
文章目录 ~~~~~~~~~~~~栈~~~~~~~~~~~~ 155. 最小栈 解法1:链表 剑指 Offer 31. 栈的压入.弹出序列 解法1:模拟栈 20. 有效的括号 解法1:栈 相似题目: ...
- 力扣刷题记录-单调栈相关题目
单调栈是指栈里的元素保持升序或者降序. 判别是否需要使用单调栈:通常是一维数组里面,需要寻找一个元素左边或者右边第一个比自己大或者小的元素的位置,则可以考虑使用单调栈:这样的时间复杂度一般为O(n). ...
- leetcode 42. 接雨水 思考分析(暴力、动态规划、双指针、单调栈)
目录 题目 思路 暴力法 动态规划 双指针法 单调栈 题目 给定 n 个非负整数表示每个宽度为 1 的柱子的高度图,计算按此排列的柱子,下雨之后能接多少雨水. 输入:height = [0,1,0,2 ...
- 六十五、下一个更大的数系列,单调栈解决方法
@Author:Runsen 编程的本质来源于算法,而算法的本质来源于数学,编程只不过将数学题进行代码化. ---- Runsen 据说,放张小姐姐觉得照片可以提高阅读量,图是来源学校的2020新生. ...
- 2019ICPC(银川) - Largest Common Submatrix(单调栈)
题目链接:点击查看 题目大意:给出两个n*m的矩阵,问最大的公共子矩阵的面积是多少 题目分析:一开始看到这个题目是想到了一个n^4的算法..就是暴力枚举,肯定是不行的了,最后的时候还是队友把思路一步步 ...
- 将一个数组中的值按逆序重新排放。_六十五、下一个更大的数系列,单调栈解决方法...
「@Author:Runsen」 ❝ 编程的本质来源于算法,而算法的本质来源于数学,编程只不过将数学题进行代码化. 「---- Runsen」 ❞ 据说,放张小姐姐觉得照片可以提高阅读量,图是来源学校 ...
- [数据结构]——单调栈
单调栈 笔者在做leetcode的题(下一个出现的最大数字)时,接触到了单调栈这一种数据结构,经过研究之后,发现单调栈在解决某些问题时出奇的好用,下面是对单调栈的性质和一些典型题目. 什么是单调栈? ...
- LeetCode42题,单调栈、构造法、two pointers,这道Hard题的解法这么多?
本文始发于个人公众号:TechFlow,原创不易,求个关注 今天是LeetCode专题的第23篇文章. 今天来看一道很有意思的题,它的难度是Hard,并且有许多种解法. 首先我们来看题面,说是我们有若 ...
最新文章
- 计算机科学与技术专业术语
- DBA(二):percona软件、innobackupex备份与恢复
- C++之error: cannot bind non-const lvalue reference of type ‘myString’ to an rvalue of type ‘myString
- 是什么包_包粽子教程,喜欢的收藏,以后想吃什么样的都可以自己包
- 一个在线编写前端代码的好玩的工具
- C++中多态的基本概念以及虚表的基本概念
- html5游戏制作入门系列教程(八)
- Smack 4.3.2 发布,XMPP(jabber) 的 Java 客户端类库
- 零基础学习IOS开发(二)- 使用cocos2d-x3.0 执行Hello world
- (转)AIX rootvg 镜像创建与磁盘更换
- 【BZOJ3191】【JLOI2013】卡牌游戏 [DP]
- 【GIS教程】土地利用转移矩阵、土地利用面积变化
- 恩智浦智能车(CNYouth)
- Mysql数据库的备份与恢复
- PTA(Java类与对象 方法,方法重载) 7-1 设计一个风扇Fan类
- EMV(一):初步了解EMV和EMV的分层结构
- HTML+CSS美食静态网页设计——简单牛排美食餐饮(9个页面)公司网站模板企业网站实现
- RTMP视频推流功能组件EasyRTMP-HIK DEMO版本运行报错0xc000007b问题排查分析
- 封神台SQL注入-宽字节
- 框架设计:浅谈ECS设计思想(一)
热门文章
- Token注解防止表单的重复提交
- 在javaweb中通过servlet类和普通类读取资源文件
- 享受Android应用程序的Java技术盛宴
- 移动端ajax,jQuery基于$.ajax设置移动端click超时处理方法
- LOAD DATA INFILE 语法
- 球球大作战测试服android版,球球大作战10.0体验服
- AUTOSAR从入门到精通100讲(二十九)-AutoSar中RTE的生成过程
- 牛客网-数据结构笔试题目(三)-博弈论圆圈游戏(Circle Game)(附源码)
- 大整数乘法c语言代码_大整数乘法
- linux下编译openjdk7,Ubuntu 14.04.3 64位环境下OpenJDK7编译