题目大意:给出一段无序数组找出任意 一段区间和*这段区间的最小值 使这个值最大
栈的经典问题
用栈预处理出当前ai 为这块区间最小值的时候 的区间范围(L 和R)
#include<bits/stdc++.h> using namespace std; #define maxn 100015 #define LL long long LL ll[maxn],rr[maxn]; stack<LL >s,t; LL sum[maxn]; LL a[maxn]; int main(){ //freopen("feelgood.in","r",stdin); //freopen("feelgood.out","w",stdout); LL n; cin>>n; memset(sum,,sizeof(sum)); ;j<=n;j++){ cin>>a[j]; sum[j]=a[j]+sum[j-]; } ;j<=n;j++){ while(s.size()&&a[j]<=a[s.top()]){ s.pop(); } ; ; s.push(j); } ;j--){ while(t.size()&&a[j]<=a[t.top()]){ t.pop(); } if(!t.size()) rr[j]=n; ; t.push(j); //cout<<rr[j]<<endl; } LL mx=-,l,r; ;j<=n;j++){ LL ans=1LL*a[j]*(sum[rr[j]]-sum[ll[j]-]); if(ans>mx){ mx=ans; l=ll[j]; r=rr[j]; } } cout<<mx<<endl; cout<<l<<" "<<r<<endl; }