luoguP1823 [COI2007] Patrik 音乐会的等待
题目描述
N个人正在排队进入一个音乐会。人们等得很无聊,于是他们开始转来转去,想在队伍里寻找自己的熟人。队列中任意两个人A和B,如果他们是相邻或他们之间没有人比A或B高,那么他们是可以互相看得见的。
写一个程序计算出有多少对人可以互相看见。
输入格式
输入的第一行包含一个整数N (1 ≤ N ≤ 500 000), 表示队伍中共有N个人。
接下来的N行中,每行包含一个整数,表示人的高度,以毫微米(等于10的-9次方米)为单位,每个人的调度都小于2^31毫微米。这些高度分别表示队伍中人的身高。
输出格式
输出仅有一行,包含一个数S,表示队伍中共有S对人可以互相看见。
输入输出样例
输入
输出
解题思路
单调栈
AC Code
#include<stack>
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
#define ll long long
stack<pair<int,int> > S;
int main(){
int n;
scanf("%d",&n);
ll cnt=;
for(int i=;i<=n;i++){
int k;
scanf("%d",&k);
pair<int,int> p(k,);
for(;!S.empty()&&S.top().first<=k;S.pop()){
cnt+=S.top().second;
if(S.top().first==k)p.second+=S.top().second;
}
if(!S.empty())++cnt;
S.push(p);
}
return cout<<cnt,;
}
luoguP1823 [COI2007] Patrik 音乐会的等待的更多相关文章
- 洛谷 P1823 [COI2007] Patrik 音乐会的等待
		洛谷 P1823 [COI2007] Patrik 音乐会的等待 洛谷传送门 题目描述 N个人正在排队进入一个音乐会.人们等得很无聊,于是他们开始转来转去,想在队伍里寻找自己的熟人.队列中任意两个人A ... 
- 洛谷 P1823 [COI2007] Patrik 音乐会的等待 题解
		P1823 [COI2007] Patrik 音乐会的等待 题目描述 N个人正在排队进入一个音乐会.人们等得很无聊,于是他们开始转来转去,想在队伍里寻找自己的熟人.队列中任意两个人A和B,如果他们是相 ... 
- 洛谷P1823 [COI2007] Patrik 音乐会的等待(单调栈+二分查找)
		洛谷P1823 [COI2007] Patrik 音乐会的等待(单调栈+二分查找) 标签:题解 阅读体验:https://zybuluo.com/Junlier/note/1333275 这个题不是很 ... 
- P1823 [COI2007] Patrik 音乐会的等待  单调栈 洛谷luogu
		题目描述 N个人正在排队进入一个音乐会.人们等得很无聊,于是他们开始转来转去,想在队伍里寻找自己的熟人.队列中任意两个人A和B,如果他们是相邻或他们之间没有人比A或B高,那么他们是可以互相看得见的. ... 
- [COI2007] Patrik 音乐会的等待 (单调栈,模拟)
		题目描述 N个人正在排队进入一个音乐会.人们等得很无聊,于是他们开始转来转去,想在队伍里寻找自己的熟人.队列中任意两个人A和B,如果他们是相邻或他们之间没有人比A或B高,那么他们是可以互相看得见的. ... 
- 洛谷P1823 [COI2007] Patrik 音乐会的等待
		https://www.luogu.org/problemnew/show/P1823 自己只会一个log的 设取的人的位置分别是l,r(l<r) 这个做法大概是考虑枚举r,设法对于每个r求出有 ... 
- 洛谷 1823 [COI2007] Patrik 音乐会的等待
		[题解] 维护一个单调栈即可. 但是因为有相同身高的存在,所以要稍微考虑下相同身高的处理.因为这个卡了一下下QAQ... #include<cstdio> #include<algo ... 
- [COI2007] Patrik 音乐会的等待 单调栈
		Code: #include<cstdio> #include<algorithm> #include<iostream> #include<cstring& ... 
- [COI2007] [luogu P1823] Patrik 音乐会的等待 解题报告 (单调栈)
		题目链接:https://www.luogu.org/problemnew/show/P1823 题目: N个人正在排队进入一个音乐会.人们等得很无聊,于是他们开始转来转去,想在队伍里寻找自己的熟人. ... 
随机推荐
- LArea插件选中城市,确定之后又很难再次选择城市?
			加上fastclick.js这个js就能解决这个问题啦...... 详情:http://blog.csdn.net/zfy865628361/article/details/49512095 
- 教你怎样用fluent长网格【转载】
			转载地址: http://blog.sina.cn/dpool/blog/s/blog_63a80e870100k1jo.html?type=-1 有的时候,当你十月怀胎,千辛万苦把网格生出来,导入f ... 
- SignalR的几种方式_转自:https://www.cnblogs.com/zuowj/p/5674615.html
			SignalR有三种传输模式: LongLooping(长轮询). WebSocket(HTML5的WEB套接字). Forever Frame(隐藏框架的长请求连接), 可以在WEB客户端显式指定一 ... 
- Mybatis异常-java.lang.IllegalArgumentException: invalid comparison:java.util.Date and java.lang.String
			原因:在Mapper.xml中对非字符串类型的数据进行了是否为空判断,如date类型的数据Create_Date != '',decimal类型的数据price != ''都会报这个错误 只有字符串才 ... 
- css去除图片间隙
			问题如下图 把图片转换成块状元素即可 .img{ display: block; } 解决后: 
- Mysql  按年、季度、月、周查询统计
			User表 CREATE TABLE `user` ( `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '用户ID', `username` varchar( ... 
- Fish Lang
			fish lang是一门基于函数的,可定制语法的编程语言. 为什么要设计fish这门语言 目前的编程语言语法都是固定死的,无法很容易的移除一种语法.fish语言一切语法由函数定义,语言只提供一个函数的 ... 
- How to Hack Unity Games using Mono Injection Tutorial
			https://guidedhacking.com/threads/how-to-hack-unity-games-using-mono-injection-tutorial.11674/ Unity ... 
- GIS空间分析案例_图层逐要素导出地理处理工具
			GIS空间分析案例_图层逐要素导出地理处理工具 商务合作,科技咨询,版权转让:向日葵,135-4855__4328,xiexiaokui#qq.com 目的:导出图层的每个要素 使用方法:指定输入图层 ... 
- 蓝牙BLE: 蓝牙4.0 BLE广播数据解析(转)
			BLE 设备工作的第一步就是向外广播数据.广播数据中带有设备相关的信息.本文主要说一下 BLE 的广播中的数据的规范以及广播包的解析. 1. 广播模式 BLE 中有两种角色 Central 和 Per ... 
