Week--5 A - 最大矩形

给一个直方图,求直方图中的最大矩形的面积。例如,下面这个图片中直方图的高度从左到右分别是2, 1, 4, 5, 1, 3, 3, 他们的宽都是1,其中最大的矩形是阴影部分。


1.png

Input
输入包含多组数据。每组数据用一个整数n来表示直方图中小矩形的个数,你可以假定1 <= n <= 100000. 然后接下来n个整数h1, ..., hn, 满足 0 <= hi <= 1000000000. 这些数字表示直方图中从左到右每个小矩形的高度,每个小矩形的宽度为1。 测试数据以0结尾。

Output
对于每组测试数据输出一行一个整数表示答案。

Sample Input
7 2 1 4 5 1 3 3
4 1000 1000 1000 1000
0

Sample Output
8
4000
实现思路:
依据题意,对于每个小矩形我们需要向前向后分别找到第一个比它低的矩形,此时得到的便为其所能构成的最大矩形,因此我们需要构建单调递增栈来储存当前遍历到的满足条件的最大矩形。最后依次从栈中找出各部分最大值,取最大面积输出。

实现代码如下:

#include<cstdio>
#include<iostream>
#include<stack> 
#include<cmath>
#include<algorithm>
using namespace std;
const int maxn=1e5+10;

struct tran{
    long long high;
     int index;
}t[maxn];
int main()
{
    while(true)
    {
        int n;
        cin>>n;
        if(n==0)break;
        stack<tran>s;
        long long ans=0;
        for(int i=1;i<n+1;i++)
        {
            scanf("%lld",&t[i].high);
            t[i].index=i;
            int index;//当前小矩形位置
            int left=i;//最左侧端点
            long long h;//当前小矩形高度

            //查找当前最大矩形
            while(!s.empty()){
                index=s.top().index;
                h=s.top().high;
                if(h>=t[i].high)
                {
                    s.pop();
                    left=index;
                    ans=max(ans,h*(i-left));
                }
                else
                {
                    break;
                }
              }s.push({t[i].high,left});//当前最大矩形入栈
        }
               //找出栈中最大矩形面积
        while(!s.empty()){
            int index;
            int left;
            long long h;
            index=s.top().index;
            h=s.top().high;
                s.pop();
                left=index;
                ans=max(ans,h*(n+1-left));
            }
        printf("%lld\n",ans);
    }
    
  
    return 0;
}

小结:利用单调递增栈(单调递减栈)处理问题可以以O(n)的复杂度处理针对每个数,寻找它和它左 / 右边第一个比它大 / 小的数的值,以及相距多少个数的问题。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,132评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,802评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,566评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,858评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,867评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,695评论 1 282
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,064评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,705评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,915评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,677评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,796评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,432评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,041评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,992评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,223评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,185评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,535评论 2 343

推荐阅读更多精彩内容

  • 试题编号: 201312-3试题名称: 最大的矩形时间限制: 1.0s内存限制: 256.0MB问...
    YAFree阅读 353评论 0 0
  • 1. file n. 文件;v. 保存文件2. command n. 命令指令3. use v. 使用用途4. p...
    喵呜Yuri阅读 748评论 0 4
  • 题目 给定一个整数map,其中的值只有0和1两种,求其中全是1的所有矩形区域中最大的矩形区域为1的数量。  例如:...
    呤雪情枫阅读 543评论 0 1
  • 就是一些很神奇的数据结构 A:最大矩形 题目: 给一个直方图,求直方图中的最大矩形的面积。例如,下面这个图片中直方...
    大家好我是阿凉阅读 399评论 0 0
  • 计划的几个出行方案都因时间原因放弃了,最终选择了没有太多期待的港澳行,特别是此次无法实现米埔之行,还是很遗憾...
    40b14b8a6983阅读 170评论 0 0