博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
直方图中最大矩形面积
阅读量:5085 次
发布时间:2019-06-13

本文共 1719 字,大约阅读时间需要 5 分钟。

原文地址: 

注意:本文并未对原文完整翻译,而是结合原文并根据本人理解写出,因此部分内容为完整翻译,部分内容为个人理解所写。

Largest Rectangle in Histogram 直方图中最大矩形面积

一个直方图是由许多矩形组成,在给定的直方图中找出最大的矩形面积。为了简化问题,假定所有矩形宽度都为1个单位。

例如,下面的直方图中有7个矩形,高度分别是(6,2,5,4,5,2,6)。最大的矩形面积是12(如下图所示,最大矩形面积用红色方框标出)

最大矩形面积

下面给出的解决方法时间复杂度为O(n)。矩形面积的计算公式为底*高。对于直方图中的每个矩形’x’(例如图中高度为6,2或5的矩形)以该矩形的高度为高(因为在直方图中最大矩形的高必然是某个单独矩形高),然后计算出最大矩形面积。因此接下来的问题是,若以某个矩形的高度为高,那么最终矩形的左边界和右边界在哪里?确定两个边界后就可以得到宽度,最终计算出面积。

我们从左向右遍历每个矩形,并通过一个栈来存储这些矩形高度在输入数组中的索引。每个矩形(索引)仅压入栈中一次。当输入的矩形高度小于栈顶矩形的高度,那么栈顶矩形将会被弹出,然后计算矩形面积,其中矩形面积的高为弹出单个矩形条的高。现在得到了高,接下来得到左右边界后便可计算出宽度。由于当前输入的矩形i的高度小于栈顶矩形,那么以栈顶为高的矩形右边界为i。而在当前栈中若非空,那么栈中矩形条的高度一定是小于等于弹出的矩形的高度,因此左边界就确定了。(当有多个连续的高度一样的矩形条时,计算最后一个出栈的矩形时会得到最终的面积)

最终步骤归纳为:

  1. 创建一个空栈
  2. 从第一个矩形条开始,对每个矩形条的高度height[i] (i的取值范围是[0,n-1])执行下面两步 
    a) 如果栈为空,或height[i]大于等于栈顶元素,那么将矩形条i压入栈中。 
    b)如果输入的矩形条高度小于栈顶元素高度,那么将栈顶元素在输入数组中的索引tp出栈,然后计算矩形面积。矩形的高为height[tp],而右边界为i,左边界为当前栈顶元素对应的索引,若栈为空,则宽度就是i。
  3. 经过计算后,栈非空,然后将栈中元素逐个弹出,并按照步骤2计算矩形面积,并且更新最大值。

总结:若输入序列是是升序,那么依次入栈,让入栈元素小于栈顶,以栈顶元素为高的矩形左边界必然是将高出栈后新的栈顶元素的位置(因为是按升序入栈)。而栈中元素是按升序排列那么以栈中任意一个元素为高,必然可以和栈顶元素构成矩形,所以当即将入栈元素小于栈顶元素时,那么右边界即是这个入栈元素的索引位置。

下面是的实现代码。

public class Solution {    public int largestRectangleArea(int[] height) { Stack
s = new Stack<>(); int max_area = 0; // 最大矩形面积 int tp; // 栈顶 int area_with_top; int i = 0; int n = height.length; while (i < n) { if (s.empty() || height[s.peek()] <= height[i]) { s.push(i++); } else { tp = s.pop(); area_with_top = height[tp] * (s.empty() ? i : i - s.peek() - 1); max_area = Math.max(max_area, area_with_top); } } while (!s.empty()) { tp = s.pop(); area_with_top = height[tp] * (s.empty() ? i : i - s.peek() - 1); max_area = Math.max(max_area, area_with_top); } return max_area; } }

转载于:https://www.cnblogs.com/mfryf/p/6865897.html

你可能感兴趣的文章
python 监听端口
查看>>
Mac homebrew
查看>>
[Linux基础]Linux基础知识入门及常见命令.
查看>>
python之time模块
查看>>
Mybatis文章
查看>>
数据库任务进度记录
查看>>
#include”* .h“ 在查找预编译头使用时跳过
查看>>
HQS——Half Quadratic Splitting半二次方分裂
查看>>
PAT (Basic Level) Practise:1019. 数字黑洞
查看>>
js 九九乘法表
查看>>
如何取浏览器的当前域名
查看>>
移动端的vue项目,启动错误:Module build failed: Error: No PostCSS Config found in:
查看>>
Web基础知识
查看>>
file上传图片获取路径地址
查看>>
linux-cp命令
查看>>
Java8新特性03 Lambda表达式
查看>>
设计模式01-----builder设计模式
查看>>
运动鞋
查看>>
SQL Server 安装错误 错误代码:0x800F0906的解决方案
查看>>
[转载]来认识寄存器,内存,IO空间,IO端口,IO内存
查看>>