单调栈_Largest Rectangle in a Histogram
题面
https://flowus.cn/xjsc01/share/395ca9dc-315c-4bd5-a942-016709980c03
这里还有很多笔记(归纳好的)
https://www.acwing.com/problem/content/133/
- 直方图中最大的矩形
直方图是由在公共基线处对齐的一系列矩形组成的多边形。
矩形具有相等的宽度,但可以具有不同的高度。
例如,图例左侧显示了由高度为 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的更多相关文章
- poj 2559 Largest Rectangle in a Histogram - 单调栈
Largest Rectangle in a Histogram Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 19782 ...
- POJ 2559 Largest Rectangle in a Histogram(单调栈)
传送门 Description A histogram is a polygon composed of a sequence of rectangles aligned at a common ba ...
- leetcode Largest Rectangle in Histogram 单调栈
作者:jostree 转载请注明出处 http://www.cnblogs.com/jostree/p/4052343.html 题目链接 leetcode Largest Rectangle in ...
- poj 2559 Largest Rectangle in a Histogram (单调栈)
http://poj.org/problem?id=2559 Largest Rectangle in a Histogram Time Limit: 1000MS Memory Limit: 6 ...
- POJ 2559 Largest Rectangle in a Histogram (单调栈或者dp)
Largest Rectangle in a Histogram Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 15831 ...
- hdu 1506 Largest Rectangle in a Histogram(单调栈)
L ...
- 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 ...
- poj2559 Largest Rectangle in a Histogram(单调栈)
Description A histogram is a polygon composed of a sequence of rectangles aligned at a common base l ...
- LeetCode 84. Largest Rectangle in Histogram 单调栈应用
LeetCode 84. Largest Rectangle in Histogram 单调栈应用 leetcode+ 循环数组,求右边第一个大的数字 求一个数组中右边第一个比他大的数(单调栈 Lee ...
随机推荐
- 个人&博客信息
博客配置 服务器:无 配置链接:在博客园中安装皮肤 皮肤:GEEK by GUANGZAN 个人简介 本蒟蒻是广东中山人 如果您有一些问题,请发送邮件至mo ...
- Java学习笔记-基础语法Ⅴ
学习一些Java常用的API Math:包含执行基本数字运算的方法 如果没有构造方法,一般类的成员都是静态的,通过类名可以直接调用 Java中有两种random函数,Math.Random()函数能够 ...
- supervisor安装以及监控管理rabbitmq消费者进程
简介:Supervisor是用Python开发的一套通用的进程管理程序,能将一个普通的命令行进程变为后台daemon,并监控进程状态,异常退出时能自动重启. 1.安装 apt-get install ...
- leetcode 3. Longest Substring Without Repeating Characters 无重复字符的最长子串
一.题目大意 https://leetcode.cn/problems/longest-substring-without-repeating-characters/ 给定一个字符串 s ,请你找出其 ...
- 好客租房57-props深入(4props的默认值)
1给props设置默认值 //导入react import React from 'react' import ReactDOM from 'react-dom' import ...
- ClickHouse(01)什么是ClickHouse,ClickHouse适用于什么场景
ClickHouse的由来 ClickHouse是什么数据库?ClickHouse速度有多快?应用场景是怎么样的?ClickHouse是关系型数据库吗?ClickHouse目前是很火爆的一款面向OLA ...
- 接口测试postman深度挖掘应用②
上一篇文章我们已经介绍了postman的基本用法,以及接口测试原理.未关注博主的可以关注下博主,后期测试安全,以及各种工具用法,编程语言都会有讲解的 老样子:①先补习基础知识: ②补充上一章节由于过 ...
- torch.rand、torch.randn、torch.normal、torch.linespace
torch.rand(*size, *, out=None, dtype=None, layout=torch.strided, device=None, requires_grad=False) # ...
- Spring cloud gateway 如何在路由时进行负载均衡
本文为博主原创,转载请注明出处: 1.spring cloud gateway 配置路由 在网关模块的配置文件中配置路由: spring: cloud: gateway: routes: - id: ...
- Kafka 的稳定性
一.事务 1. 事务简介 1.1 事务场景 producer发的多条消息组成⼀个事务这些消息需要对consumer同时可⻅或者同时不可⻅ producer可能会给多个topic,多个partition ...