单调栈练习题 bad hair day

题目链接

裸单调栈的题目,直接单调栈即可

ps:必须使用数组模拟栈,不能使用stack,stack效率太低,还会爆栈,以后单调栈的题直接用数组模拟,能不用stack就不用stack

#include<bits/stdc++.h>
using namespace std;
const int maxn=100000;
int a[maxn];
int st[maxn];
long long ans;
int main()
{
	int n;
	ans=0;
	scanf("%d",&n);
	int t=0;
	int h;
	for(int i=0;i<n;i++)scanf("%d",a+i);
	for(int i=0;i<n;i++){
		if(t==0){
			st[t++]=i;
		}
		else{
			while(t>0&&a[i]>=a[st[t-1]]){
				ans+=i-st[t-1]-1;
				t--;
			}
			st[t++]=i;
		}
	}
	while(t>0){
		ans+=n-st[t-1]-1;
		t--;
	}
	printf("%lld\n",ans);
	return 0;
}

 

posted @ 2019-07-26 21:10  correct  阅读(93)  评论(0)    收藏  举报