裸单调栈的题目,直接单调栈即可
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;
}