题面

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. 个人&博客信息

                博客配置 服务器:无 配置链接:在博客园中安装皮肤 皮肤:GEEK by GUANGZAN           个人简介 本蒟蒻是广东中山人 如果您有一些问题,请发送邮件至mo ...

  2. Java学习笔记-基础语法Ⅴ

    学习一些Java常用的API Math:包含执行基本数字运算的方法 如果没有构造方法,一般类的成员都是静态的,通过类名可以直接调用 Java中有两种random函数,Math.Random()函数能够 ...

  3. supervisor安装以及监控管理rabbitmq消费者进程

    简介:Supervisor是用Python开发的一套通用的进程管理程序,能将一个普通的命令行进程变为后台daemon,并监控进程状态,异常退出时能自动重启. 1.安装 apt-get install ...

  4. leetcode 3. Longest Substring Without Repeating Characters 无重复字符的最长子串

    一.题目大意 https://leetcode.cn/problems/longest-substring-without-repeating-characters/ 给定一个字符串 s ,请你找出其 ...

  5. 好客租房57-props深入(4props的默认值)

    1给props设置默认值 //导入react     import React from 'react'     import ReactDOM from 'react-dom'     import ...

  6. ClickHouse(01)什么是ClickHouse,ClickHouse适用于什么场景

    ClickHouse的由来 ClickHouse是什么数据库?ClickHouse速度有多快?应用场景是怎么样的?ClickHouse是关系型数据库吗?ClickHouse目前是很火爆的一款面向OLA ...

  7. 接口测试postman深度挖掘应用②

    上一篇文章我们已经介绍了postman的基本用法,以及接口测试原理.未关注博主的可以关注下博主,后期测试安全,以及各种工具用法,编程语言都会有讲解的 老样子:①先补习基础知识:  ②补充上一章节由于过 ...

  8. torch.rand、torch.randn、torch.normal、torch.linespace

    torch.rand(*size, *, out=None, dtype=None, layout=torch.strided, device=None, requires_grad=False) # ...

  9. Spring cloud gateway 如何在路由时进行负载均衡

    本文为博主原创,转载请注明出处: 1.spring cloud gateway 配置路由 在网关模块的配置文件中配置路由: spring: cloud: gateway: routes: - id: ...

  10. Kafka 的稳定性

    一.事务 1. 事务简介 1.1 事务场景 producer发的多条消息组成⼀个事务这些消息需要对consumer同时可⻅或者同时不可⻅ producer可能会给多个topic,多个partition ...