poj 2559 Largest Rectangle in a Histogram 求面積最大的矩形(單調棧)

Largest Rectangle in a Histogram

題目大意

給出一個數N代表有多少個矩形,然後下面有N個數代表每個矩形的高度,寬度均爲1。最後求這N個矩形組成的最大面積!

解題思路

很容易想到的就是使用單調棧。維護一個從棧頂到棧低減小的棧!
每次遇到棧頂的元素大於要壓入的元素就要,出棧然後和當前的最大面積取最大值,這樣一直下去,最後棧中就剩下一個從棧頂到棧低減小的棧。最後變爲的棧就像下面這個圖一樣!
這裏寫圖片描述

AC代碼

我看的poj的discuss裏面不讓用long long和lld,事實證明是錯。我就是用這個過的!

#include<cstdio>
#include<stack>
#include<algorithm>
#include<iostream>
using namespace std;
typedef long long LL;
typedef pair<LL,LL> PII;
const int MX = 100000 + 5;

int main()
{
    int N;
    int height;
    while(~scanf("%d",&N) &&N)
    {
        stack<PII>Q;
        LL ans = 0;
        for(int i=0;i<N;i++)
        {
            scanf("%d",&height);
            LL width = 0;
            while(!Q.empty() && Q.top().first>=height ){ //當棧頂元素大於當前元素
                LL tmpH = Q.top().first;
                LL tmpW = Q.top().second;
                Q.pop();width+=tmpW;//每次出棧的時候,就是計算以這個矩形的高度爲最長高度的最大面積,
                //因爲左邊的比他小,所以只需要向右延伸就可以了
                //所以每次出棧的時候,就是出棧後的棧頂元素寬度+1
                ans = max(ans,tmpH*width);//如果大於當前的最大面積就更新
            }
            Q.push(make_pair((LL)height,(LL)width+1));
        }
        int tmp = 0;
        while(!Q.empty()){
            ans = max(ans,Q.top().first*(tmp+Q.top().second));//原理和上面一樣
            tmp+=Q.top().second;Q.pop();
        }
        printf("%lld\n",ans);
    }
    return 0;
}
發佈了215 篇原創文章 · 獲贊 197 · 訪問量 50萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章