标签:音乐会 int top 排队 cnt st 输入 rear
【问题描述】
N个人正在排队进入一个音乐会。人们等得很无聊,于是他们开始转来转去,想在队伍里寻找自己的熟人。队列中任意两个人A和B ,如果他们是相邻或他们之间没有人比A或B高,那么他们是可以互相看得见的。写一个程序计算出有多少对人可以互相看见。
输入: 输入的第一行包含一个整数N(1≤N≤500000),表示队伍中共有N个人。接下来的N行中,每行包含一个整数,表示人的高度,以毫微米(等于10的-9次方米)为单位,每个人的调度都小于231毫微米。这些高度分别表示队伍中人的身高。
输出: 输出仅有一行,包含一个数S ,表示队伍中共有S对人可以互相看见。
【输入样例】
7
2
4
1
2
2
5
1
【输出样例】
10
#include<iostream> using namespace std; int main(){ int st[500001]={},n,m,top=1,cnt=0; cin>>n; cin>>st[1]; // 默认栈顶为1: for(int i=2; i<=n; i++){ cin>>m; if(st[top]>m){ // 如果输入的元素依次递减,直接入栈,cnt加1。 cnt++; st[++top]=m; }else{ // 如果输入的元素大于或等于栈顶元素 int rear=top; while(rear>1&&m>=st[rear]) rear--; // 计算比当前元素小的栈里元素个数。 cnt+=top-rear+1; while(top>0&&st[top]<m) top--; // 出栈,删除元素。 st[++top]=m; } } cout<<cnt; return 0; }
标签:音乐会,int,top,排队,cnt,st,输入,rear 来源: https://www.cnblogs.com/dks0313/p/16496235.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。