首页 > 其他 > 详细

POJ2559 Largest Rectangle in a Histogram

时间:2019-08-17 23:01:46      阅读:154      评论:0      收藏:0      [点我收藏+]

这道题一看我们可以发现一个木桶原理,只要有一个短的,长的就没用了,我们就可以维护一个单调栈,如果碰到比前面小的,就直接进行统计和修改,最后再设n+1个矩形高度为0来统计,注意清零

#include<bits/stdc++.h>
using namespace std;
int st[100005],w[100005],s[100005],top,a[100005],n;
long long ans;
int main(){
    while(scanf("%d",&n)==1&&n){
        int k;
        for(int i=1;i<=n;i++)
         scanf("%d",&a[i]);
        top=a[n+1]=0;//巧设
        ans=0;
        for(int i=1;i<=n+1;i++){
            if(a[i]>s[top])
             w[++top]=1,s[top]=a[i];//单调性
            else{
             int wid=0;
             while(s[top]>a[i]){
                 wid+=w[top];
                 ans=max(ans,(long long)wid*s[top]);//统计
                 top--; 
             }
             s[++top]=a[i];w[top]=wid+1;
            }
        }
        cout<<ans<<endl;
    }
}

 

POJ2559 Largest Rectangle in a Histogram

原文:https://www.cnblogs.com/coder-cjh/p/11370462.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!