【题解】hdu1506 Largest Rectangle in a Histog…

2019-11-11 16:00:53来源:博客园 阅读 ()

新老客户大回馈,云服务器低至5折

【题解】hdu1506 Largest Rectangle in a Histogram

目录

  • 题目
  • 思路
  • $Code$

题目

Largest Rectangle in a Histogram

思路

单调栈。
不知道怎么描述所以用样例讲一下。

7 2 1 4 5 1 3 3
最大矩形的高度一定是给你的高度中的一个。
我们枚举最大高度。
很明显以某一高度为高的矩形的左边界是该高度左边第一个比它矮的。
右边界类似。

我们可以用单调栈去维护每一个高度左右第一个比他矮的位置即可

$Code$

#include<iostream>
#include<cstring>
#include<string>
#include<cstdio>
#include<stack>
#include<algorithm>
#define max(a,b) a>b?a:b
#define MAXN 100001

typedef long long ll;

inline void read(ll &T) {
    ll x=0;bool f=0;char c=getchar();
    while(c<'0'||c>'9'){if(c=='-')f=!f;c=getchar();}
    while(c>='0'&&c<='9'){x=x*10+c-'0';c=getchar();}
    T=f?-x:x;
}

inline void write(ll x) {
    if(x<0) putchar('-'),write(-x);
    else {
        if(x/10) write(x/10);
        putchar(x%10+'0');
    }
}

ll n;
int l[MAXN],r[MAXN];
struct node {
    ll w,num;
}a[MAXN];
std::stack<node> sss;

signed main() {
    while(1) {
        ll maxx=0;
        read(n);if(n==0) break;
        for(int i=1;i<=n;++i) {
            read(a[i].w);a[i].num=i;
        }
        for(int i=1;i<=n;++i) {
            if(sss.empty()) {l[i]=0;sss.push(a[i]);continue;}
            node x=sss.top();
            while(x.w>=a[i].w) {
                sss.pop();
                if(sss.empty()) break;
                x=sss.top();
            }
            if(sss.empty()) l[i]=0;
            else l[i]=sss.top().num;
            sss.push(a[i]);
        }
        while(!sss.empty()) sss.pop();
        for(int i=n;i>=1;--i) {
            if(sss.empty()) {r[i]=n+1;sss.push(a[i]);continue;}
            node x=sss.top();
            while(x.w>=a[i].w) {
                sss.pop();
                if(sss.empty()) break;
                x=sss.top();
            }
            if(sss.empty()) r[i]=n+1;
            else r[i]=sss.top().num;
            sss.push(a[i]);
        }
        for(int i=1;i<=n;++i) {
            ll qwq=a[i].w*1ll*(r[i]-l[i]-1);
            maxx=max(maxx,qwq);
        }
        while(!sss.empty()) sss.pop();
        write(maxx);puts("");
    }
    return 0;
}

原文链接:https://www.cnblogs.com/poi-bolg-poi/p/11838861.html
如有疑问请与原作者联系

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:2019.11.11&amp;12题解

下一篇:STL库学习笔记(一)——什么是STL?