【题解】Largest Rectangle in a Histogram [SP1805] [POJ2559]
【题解】Largest Rectangle in a Histogram [SP1805] [POJ2559]
【题目描述】
传送: \(Largest\) \(Rectangle\) \(in\) \(a\) \(Histogram\) \([SP1805]\) \([POJ2559]\)
同一水平线上有 \(n\) 个矩形,构成了一个柱状多边形,矩形宽度均为 \(1\),高度不同。如图:

你需要在多边形中框选出一个矩形,使其面积最大,如图阴影部分。
【输入】
每组数据包含一个整数 \(n\),以及 \(n\) 个整数 \(hi\) 。
结尾以一个单独的 \(0\) 结尾。
【输出】
对于每组数据,直接输出这个最大面积 。
【样例】
输入:
7 2 1 4 5 1 3 3
4 1000 1000 1000 1000
0
输出:
8
4000
【分析】
有两种解法,递推和单调栈。
【递推】
问题转换:
假定我们选定了某一个矩形的高,那么由这个高所能得到的最大面积,就是从这个矩形的位置出发,看它最多能向左,右两边延伸多远的距离,并且乘以选定的这个高度。
如果我们能预处理出每个点向左右两边能到达的最远距离,那么这个题就 \(so\) \(easy\)。
如何求一个点向左,右延伸所能到达的极限?
对于每一个位置 \(i\),我们先把它与上一个位置 \(i-1\) 的高度作比较,如果 \(h[i] \leqslant h[i-1]\),那么 \(i-1\) 的左极限 \(L[i-1]\) 也可作为 \(i\) 的左极限。而如果 \(h[\) \(L[i-1]-1\) \(]\) \(\leqslant h[i]\),那么 \(L[i]=L[i-1]-1\) 。
右极限求法同上。
【Code】
#include<algorithm>
#include<cstdio>
#define LL long long
using namespace std;
int n,a[100005],l[100005],r[100005];LL s,ans;
int main(){
while(scanf("%d",&n)!=EOF){
if(!n)break;
ans=0;
for(int i=1;i<=n;i++){
scanf("%d",&a[i]);
l[i]=r[i]=i;//左右极限都初始化为它自己
while(l[i]>1&&a[l[i]-1]>=a[i])l[i]=l[l[i]-1];
}
for(int i=n;i;i--)
while(r[i]<n&&a[r[i]+1]>=a[i])r[i]=r[r[i]+1];
for(int i=1;i<=n;i++)//扫描,对每个点进行一次择优
ans=max(ans,(LL)a[i]*(r[i]-l[i]+1));
printf("%lld\n",ans);
}
}
【单调栈】
建立一个栈存储所有矩形的高度和宽度,宽度全部初始化为 \(1\) 。
每当读入一个点 \(i\) 的高度,判断如果它比上一个点 \(i-1\) 低,那么就进行一次假定选择 \(i-1\) 的高度的计算,计算方法就是不停的出栈,并且不断累加弹出的矩形宽度 \(wide\) ,每弹出一个,就用 \(wide\) 乘以这个弹出的矩形的高度,并且与 \(ans\) 进行一次择优。一直弹到当栈顶矩形高小于等于 \(h[i]\) 时,把一个宽度为 \(wide+1\),高度为 \(h[i]\) 的新矩形入栈。
如果它比上一个高,则直接入栈。
为方便处理最后剩余的矩形,\(把 h[n+1]\) 赋值为一个极大值。
正确性?
而实际上刚刚这样的弹栈边计算计算的方法只计算了每个点在局部所能制造出的面积。只计算每个点的局部最优显然不能得到正确答案,但它对全局所能产生影响的,仅有高度小于等于新矩形高度的下面部分,至于上面的,在以后永远也不会再选到,所以弹出后直接留下宽度送给新矩形即可保留它对全局的影响。
【Code】
#include<algorithm>
#include<cstdio>
int i,n,t,wi,a[100005],Q[100005],W[100005];
long long ans;
int main(){
while(scanf("%d",&n)!=EOF){
if(!n)break;
for(i=1;i<=n;i++)scanf("%d",&a[i]);
ans=a[n+1]=t=0;//提前预处理a[n+1];清空栈
for(i=1;i<=n+1;i++)
if(a[i]>Q[t])Q[++t]=a[i],W[t]=1;//如果仍保持单调性,则直接入栈
else{
wi=0;
while(t&&a[i]<=Q[t])ans=std::max(ans,(long long)(wi+=W[t])*Q[t--]);
//每弹出一个就计算一下:如果选定当前这个矩形向左最多能获得多大的面积收益
Q[++t]=a[i],W[t]=wi+1;//合并且入栈
}
printf("%lld\n",ans);
}
}
【题解】Largest Rectangle in a Histogram [SP1805] [POJ2559]的更多相关文章
- POJ2559 Largest Rectangle in a Histogram —— 单调栈
题目链接:http://poj.org/problem?id=2559 Largest Rectangle in a Histogram Time Limit: 1000MS Memory Lim ...
- poj2559 Largest Rectangle in a Histogram(单调栈)
Description A histogram is a polygon composed of a sequence of rectangles aligned at a common base l ...
- [POJ 2559]Largest Rectangle in a Histogram 题解(单调栈)
[POJ 2559]Largest Rectangle in a Histogram Description A histogram is a polygon composed of a sequen ...
- [POJ2559&POJ3494] Largest Rectangle in a Histogram&Largest Submatrix of All 1’s 「单调栈」
Largest Rectangle in a Histogram http://poj.org/problem?id=2559 题意:给出若干宽度相同的矩形的高度(条形统计图),求最大子矩形面积 解题 ...
- POJ2559 Largest Rectangle in a Histogram (单调栈
Largest Rectangle in a Histogram Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 26012 ...
- NYOJ-258/POJ-2559/HDU-1506 Largest Rectangle in a Histogram,最大长方形,dp或者单调队列!
Largest Rectangle in a Histogram 这么经典的题硬是等今天碰到了原题现场懵逼两小时才会去补题.. ...
- 题解报告:poj 2559 Largest Rectangle in a Histogram(单调栈)
Description A histogram is a polygon composed of a sequence of rectangles aligned at a common base l ...
- 【题解】hdu1506 Largest Rectangle in a Histogram
目录 题目 思路 \(Code\) 题目 Largest Rectangle in a Histogram 思路 单调栈. 不知道怎么描述所以用样例讲一下. 7 2 1 4 5 1 3 3 最大矩形的 ...
- DP专题训练之HDU 1506 Largest Rectangle in a Histogram
Description A histogram is a polygon composed of a sequence of rectangles aligned at a common base l ...
随机推荐
- 剑指:包含min函数的栈(min栈)
题目描述 设计一个支持 push,pop,top 等操作并且可以在 O(1) 时间内检索出最小元素的堆栈. push(x)–将元素x插入栈中 pop()–移除栈顶元素 top()–得到栈顶元素 get ...
- JS引擎是如何工作的?从调用堆栈到Promise
摘要: 理解 JS 引擎运行原理. 作者:前端小智 原文:JS引擎:它们是如何工作的?从调用堆栈到Promise,需要知道的所有内容 Fundebug经授权转载,版权归原作者所有. 为了保证可读性,本 ...
- Linux的权限管理操作-Linux从入门到精通第八天(非原创)
文章大纲 一.网络相关概述二.网络相关命令三.项目上线流程(必须掌握)四.学习资料下载五.参考文章 一.网络相关概述 1. 网络发展 1.1 信息传递远古时期,人们就通过简单的语言.壁画等方式交 ...
- day 68
目录 表单指令 条件指令 循环指令 分隔符 过滤器 计算属性 监听属性 表单指令 v-model="变量",变量值与表单标签的value相关 v-model可以实现数据的双向绑定, ...
- Cron Expressions——Cron 表达式(QuartZ调度时间配置)
如果你需要像日历那样按日程来触发任务,而不是像SimpleTrigger 那样每隔特定的间隔时间触发,CronTriggers通常比SimpleTrigger更有用. 使用CronTrigger,你可 ...
- LoadRunner脚本录制常见问题
LoadRunner录制脚本时为什么不弹出IE浏览器?当一台主机上安装多个浏览器时,LoadRunner录制脚本经常遇到不能打开浏览器的情况,可以用下面的方法来解决. 启动浏览器,打开Internet ...
- Linux服务器安全加固
关于对公司网站服务器安全加固的一些想法及思路: 一.修改密码和ssh登录端口,并且尽可能的用密钥对登录,禁止用密码登录(主要针对Linux)二.修改/etc/hosts.allow 设置仅仅允许某几台 ...
- windows平台上MongoDB安装配置
我按照原文方法操作,无法连接mongod服务,可能哪里出了问题. 以下是小页的教程:https://www.cnblogs.com/littlepage/p/10992336.html 视频参考: ...
- python抓取网站提示错误ssl.SSLCertVerificationError处理
python在抓取制定网站的错误提示:ssl.SSLCertVerificationError: [SSL: CERTIFICATE_VERIFY_FAILED] certificate verify ...
- 如何让wordpress后台搜索只匹配搜索文章标题
今天编辑小美眉问网站wordpress后台能不能实现只搜索标题,这个问题怎么可能难到ytkah呢?打开Stack Overflow一顿狂搜,总数有解决方案了,哈哈哈!一起来看看怎么操作吧. 打开主题目 ...