题面

https://flowus.cn/xjsc01/share/395ca9dc-315c-4bd5-a942-016709980c03
这里还有很多笔记(归纳好的)

https://www.acwing.com/problem/content/133/

  1. 直方图中最大的矩形
    直方图是由在公共基线处对齐的一系列矩形组成的多边形。
    矩形具有相等的宽度,但可以具有不同的高度。
    例如,图例左侧显示了由高度为 2,1,4,5,1,3,3
    的矩形组成的直方图,矩形的宽度都为 1

通常,直方图用于表示离散分布,例如,文本中字符的频率。
现在,请你计算在公共基线处对齐的直方图中最大矩形的面积。
图例右图显示了所描绘直方图的最大对齐矩形。

输入格式

输入包含几个测试用例。
每个测试用例占据一行,用以描述一个直方图,并以整数 n
开始,表示组成直方图的矩形数目。
然后跟随 n
个整数 h1,…,hn。
这些数字以从左到右的顺序表示直方图的各个矩形的高度。
每个矩形的宽度为 1。
同行数字用空格隔开。
当输入用例为 n=0
时,结束输入,且该用例不用考虑。

输出格式

对于每一个测试用例,输出一个整数,代表指定直方图中最大矩形的区域面积。
每个数据占一行。
请注意,此矩形必须在公共基线处对齐。

数据范围

1≤n≤100000
,
0≤hi≤1000000000

输入样例:

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

输出样例:

8
4000

题解

在这道题目中,通过忽略不可能发生情况,并把之前的情况转化成规整的,统一的情况(高度有序),以便于处理(可以删除高度大的)。
单调栈就是一种维持相对规整的一种方案。并且通过他可以忽略次要的情况。
考虑 一种情况:

遇到下一个是红颜色的方块,这是候中间两个方块的高度已经变得完全用不上了。所以要考虑如果使用这两个方块的高度,由于是单调的,最右端卡到红色方块的左边界,最左端随着指针的左移,宽度增大,高度减小,向左移动一个,就维护一下。
最后的话,把中间两个还有最右面的并到一起。

错误解析

if(h[p] == a[i]) w[p]++;
else
{
p++;
h[p] = a[i];
w[p] = 1+wid;
}

注意在这里,第一行的w[p]++,如果要是有经过删了一些中间块然后再让w[p]++;显然是错误的。
应该是w[p] += wid+1;

代码

#include <bits/stdc++.h>
using namespace std;
#define MAX 100006
//100006
typedef long long ll;
int a[MAX], w[MAX], h[MAX];
ll ans = 0;
void Solve(int n)
{
ans = 0;//对于全局变量,一定要初始化
int p = 0;
for(int i = 1; i <= n; i++) scanf("%d", a+i);
a[n+1] = 0;//到了最后一定要把所有的长方形全部处理一遍,不然会有遗漏!!
for(int i = 1; i <= n+1; i++)
{
if(a[i] > h[p])
{
p++;
h[p] = a[i];
w[p] = 1;
}
else//小于或者是等于
{
int wid = 0;
while(h[p] > a[i])
{
wid += w[p];
ans = max(ans, (ll)wid * h[p]);//计算结果的精髓
p--;
} if(h[p] == a[i]) w[p] += wid + 1;
else
{
p++;
h[p] = a[i];
w[p] = 1+wid;
} }
}
printf("%lld\n", ans);
}
int main()
{
int n;
while(scanf("%d", &n) && n) Solve(n);
return 0;
}

单调栈_Largest Rectangle in a Histogram的更多相关文章

  1. poj 2559 Largest Rectangle in a Histogram - 单调栈

    Largest Rectangle in a Histogram Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 19782 ...

  2. POJ 2559 Largest Rectangle in a Histogram(单调栈)

    传送门 Description A histogram is a polygon composed of a sequence of rectangles aligned at a common ba ...

  3. leetcode Largest Rectangle in Histogram 单调栈

    作者:jostree 转载请注明出处 http://www.cnblogs.com/jostree/p/4052343.html 题目链接 leetcode Largest Rectangle in ...

  4. poj 2559 Largest Rectangle in a Histogram (单调栈)

    http://poj.org/problem?id=2559 Largest Rectangle in a Histogram Time Limit: 1000MS   Memory Limit: 6 ...

  5. POJ 2559 Largest Rectangle in a Histogram (单调栈或者dp)

    Largest Rectangle in a Histogram Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 15831 ...

  6. hdu 1506 Largest Rectangle in a Histogram(单调栈)

                                                                                                       L ...

  7. Largest Rectangle in a Histogram HDU - 1506 (单调栈)

    A histogram is a polygon composed of a sequence of rectangles aligned at a common base line. The rec ...

  8. poj2559 Largest Rectangle in a Histogram(单调栈)

    Description A histogram is a polygon composed of a sequence of rectangles aligned at a common base l ...

  9. LeetCode 84. Largest Rectangle in Histogram 单调栈应用

    LeetCode 84. Largest Rectangle in Histogram 单调栈应用 leetcode+ 循环数组,求右边第一个大的数字 求一个数组中右边第一个比他大的数(单调栈 Lee ...

随机推荐

  1. 震惊--Nginx的map指令还能这样用

    map指令简单介绍 当然这里写的都是官方文档是已经写过的,我简单抄一下哈. map指令来自于 ngx_http_map_module 模块,提供的核心能力是 基于一个变量创建一个新变量,大概是这意思. ...

  2. 版本控制之git

    1.Git的介绍 Git 是一个开源的分布式版本控制软件,用以有效.高速的处理从很小到非常大的项目版本管理. Git 最初是由Linus Torvalds设计开发的,用于管理Linux内核开发.Git ...

  3. 面试官:ElasticSearch是什么,它有什么特性与使用场景?

    哈喽!大家好,我是小奇,一位热爱分享的程序员 小奇打算以轻松幽默的对话方式来分享一些技术,如果你觉得通过小奇的文章学到了东西,那就给小奇一个赞吧 文章持续更新 一.前言 书接上回,我本以为我跟面试我的 ...

  4. 283. Move Zeroes - LeetCode

    Question 283. Move Zeroes Solution 题目大意:将0移到最后 思路: 1. 数组复制 2. 不用数组复制 Java实现: 数组复制 public void moveZe ...

  5. MySQL8小时问题

    一.问题 获取MySQL连接,8小时内无请求自动断开连接. 二.解决 2.1 分析 MySQL服务器默认的"wait_timeout"是28800秒即8小时,意味着如果一个连接的空 ...

  6. 119_Power Pivot 长尾明细显示为【其他】

    博客:www.jiaopengzi.com 焦棚子的文章目录 请点击下载附件 一.背景 最近比较忙,太久不没有更新文章,确实没有好的素材,就写一个吧. 在关于产品数据分析的时候,我们经常关注的是主要的 ...

  7. declare-声明限定类型变量

    用于声明变量并设置变量的属性. 语法 declare [+/-][rxi][变量名称=设置值] declare -f 特殊符号 +/- "-"可用来指定变量的属性,"+& ...

  8. Kafka到底有多高可靠?(RNG NB)

    在聊Kafka高可靠之前,先在评论区来波RNG NB好不好! 什么叫可靠性? 大家都知道,系统架构有三高:「高性能.高并发和高可用」,三者的重要性不言而喻. 对于任意系统,想要同时满足三高都是一件非常 ...

  9. Java ES 实现or查询

    es mapping里有三个字段: A:Integer B:Integer C:TEXT 现在想实现一个查询,来检索  (  (A =1 and B=2)  or (c like "test ...

  10. Docker的网络

    概述 docker使用Linux桥接网卡,在宿主机虚拟一个docker容器网桥(docker0),docker启动一个容器时会根 据docker网桥的网段分配给容器一个IP地址,称为Container ...