poj 2559 Largest Rectangle in a Histogram 求面积最大的矩形(单调栈)

原创 2016年08月31日 00:05:03

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;
}
版权声明:本文为博主原创文章,转载请注明出处

poj2559(单调栈)最大矩形面积

//单调栈 //思路很好的 #include #include using namespace std; const int mn=100005; int n,h[mn],st[mn],top,l[...
  • update7
  • update7
  • 2017年08月07日 19:37
  • 10590

POJ2082 最大矩形面积 单调栈

【题目链接】           点击打开链接 【题意】           给了一些h*w的矩形,大小可不等,求可组成的最大矩形面积是多少?单调栈经典题,做法和点击打开链接 完全相同。 ...

POJ2559 最大矩形面积

给定从左到右多个矩形,已知这此矩形的宽度都为1,长度不完全相等。这些矩形相连排成一排,求在这些矩形包括的范围内能得到的面积最大的矩形,打印出该面积。所求矩形可以横跨多个矩形,但不能超出原有矩形所确定的...

单调栈(poj -- 2559)

给定从左到右多个矩形,已知这此矩形的宽度都为1,长度不完全相等。这些矩形相连排成一排,求在这些矩形包括的范围内能得到的面积最大的矩形,打印出该面积。所求矩形可以横跨多个矩形,但不能超出原有矩形所确定的...

POJ 2559 水题

点击打开链接 题意:给出一些连续的高度,求最大可以形成的长方形 思路:对于每一个高度求出它左右用这个高度可以覆盖到的左右两个位置,用L[i]和R[i]来保存,相乘后输出最大值即可 #include ...
  • Dan__ge
  • Dan__ge
  • 2016年03月14日 19:53
  • 612

POJ-2559(单增栈)

【题目描述】 给出一系列的1*h的矩形,求矩形的最大面积。 如图: 可转化为求找一个子序列。 使得这个序列的长度乘以序列最小数最大。 分析:这是一个单调栈的问题,维护栈单调不减。 单调栈 主要...

POJ 2559 单调栈 Histogram

题目在http://poj.org/problem?id=2559。 这个题目是一个好朋友给我讲的方法,我按照自己的理解,敲出来代码。 所以把算法流程和代码贡献出来,希望和大家共同学习。 ...
  • hopeztm
  • hopeztm
  • 2012年08月15日 12:37
  • 5117

POJ-2559-Largest Rectangle in a Histogram-单调栈

朴素做法就是 枚举每一个i的高度  为矩形的宽,然后往两边搜索得到最长的矩形   把所有答案比较一遍得到最大的ans 当然,这样做会超时。一个可以优化的地方就是 n次枚举中,有很多次是可以省略掉的,用...
  • viphong
  • viphong
  • 2015年08月25日 22:37
  • 547

【ACM】最大的矩形

最大的矩形问题描述试题编号: 3 试题名称: 最大的矩形 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 在横轴上放了n个相邻的矩形,每个矩形的宽度是1,而第i(1 ≤...

hdu 1268 积木堆砌的城堡(贪心)

积木堆砌的城堡 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submi...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:poj 2559 Largest Rectangle in a Histogram 求面积最大的矩形(单调栈)
举报原因:
原因补充:

(最多只允许输入30个字)