LeetCode第[84]题(Java):Largest Rectangle in Histogram(最大的矩形柱状图)
题目:最大的矩形柱状图
难度:hard
题目内容:
Given n non-negative integers representing the histogram's bar height where the width of each bar is 1, find the area of largest rectangle in the histogram.
翻译:
给定n个非负整数表示直方图的杆高度,其中每个条的宽度为1,找出直方图中最大矩形的面积。

Above is a histogram where width of each bar is 1, given height = [2,1,5,6,2,3].

The largest rectangle is shown in the shaded area, which has area = 10 unit.
我的思路:对每个元素都向两边进行搜索,如果高度大于它面积就+它,最后取最大。
我的代码:
public int largestRectangleArea(int[] height) {
int max = 0;
for (int i = 0; i < height.length; i++) {
max = Math.max(max, getArea(height, i));
}
return max;
}
private int getArea(int[] height, int i) {
int area = height[i];
for (int j = i+1; j < height.length; j++) {
if (height[j] >= height[i]) {
area += height[i];
} else {
break;
}
}
for (int j = i-1; j > -1; j--) {
if (height[j] >= height[i]) {
area += height[i];
} else {
break;
}
}
return area;
}
我的复杂度:O(N2) 空间复杂度O(1)
编码过程中的问题:
1、之前只往后面搜索没有往前;
2、方法复杂度太高,须优化。
答案代码:
public int largestRectangleArea(int[] height) {
int len = height.length;
Stack<Integer> s = new Stack<Integer>();
int maxArea = 0;
for(int i = 0; i <= len; i++){
int h = (i == len ? 0 : height[i]);
if(s.isEmpty() || h >= height[s.peek()]){
s.push(i);
}else{
int tp = s.pop();
maxArea = Math.max(maxArea, height[tp] * (s.isEmpty() ? i : i - 1 - s.peek()));
i--;
}
}
return maxArea;
}
答案复杂度:O(N) 空间复杂度O(N)
答案思路:
思路理解了半天,表示很难想到,那就直接解释好了:
利用一个栈,“递增”的块则直接压入栈中,否则(停止递增时),则将栈顶出栈,乘以上一个比他矮的下标(也就是它出栈后的栈顶)与当前指针的高度,
这样就能表示当前指针的“前一个比它高的块”的最大面积,与最大值比较之后,需要将指针 i 再-1,用来继续探测当前指针“前一块比它高的”。(从下标0一直判断到length,当下标为length的时候,高度为0)
特殊情况:
出栈后,栈内已经为空的时候,说明从最开始(下标 0),到目前为止(下标 i 的前一个),最低点就是刚刚出栈的那一个。所以此时只需要直接用此高度乘以 i 即可(相当于出栈后的栈顶是 - 1)。
示例:【2,1,3,5】
下标 操作
0 栈内空,0入栈(注意,入栈的是下标,取出来比较的时候要写成height[stack.peek()])。此时栈内【0】
1 1比栈顶下标0所表示高度2小,下标0出栈,栈空(前面比2小的没了),所以 area = 2 * i = 2;此时栈内【空】
继续判断,栈空,1入栈。此时栈内【1】
2 3比栈顶1所示高度1大,下标2入栈。此时栈内【1,2】
3 5比栈顶2所示高度3大,下标3入栈。此时栈内【1,2,3】
4 0比栈顶3所示高度5小,下标3出栈,栈顶为2(前面比高度5矮的下标2的那个),所以 area = 5 * (4-2-1) = 5;此时栈内【1,2】
继续判断,0比栈顶2所示高度3小,下标2出栈,栈顶为1(前面比高度3矮的是的下标1的那个),所以 area = 3 * (4-1-1) = 6;此时栈内【1】
继续判断,0比栈顶1所示高度1小,下标1出栈,栈为空,所以 area = 1 * i = 4;此时栈内【空】
继续判断,栈空,0入栈。此时栈内【0】
综上取最大area =》 6
LeetCode第[84]题(Java):Largest Rectangle in Histogram(最大的矩形柱状图)的更多相关文章
- leetCode 84.Largest Rectangle in Histogram (最大矩形直方图) 解题思路和方法
Given n non-negative integers representing the histogram's bar height where the width of each bar is ...
- 73.Largest Rectangle in Histogram(最大矩形)
Level: Hard 题目描述: Given n non-negative integers representing the histogram's bar height where the ...
- LeetCode 84. 柱状图中最大的矩形(Largest Rectangle in Histogram)
题目描述 给定 n 个非负整数,用来表示柱状图中各个柱子的高度.每个柱子彼此相邻,且宽度为 1 . 求在该柱状图中,能够勾勒出来的矩形的最大面积. 以上是柱状图的示例,其中每个柱子的宽度为 1,给定的 ...
- 【LeetCode】84. Largest Rectangle in Histogram 柱状图中最大的矩形(Python)
作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 单调栈 日期 题目地址: https://leetc ...
- LeetCode 84. Largest Rectangle in Histogram 单调栈应用
LeetCode 84. Largest Rectangle in Histogram 单调栈应用 leetcode+ 循环数组,求右边第一个大的数字 求一个数组中右边第一个比他大的数(单调栈 Lee ...
- Java for LeetCode 084 Largest Rectangle in Histogram【HARD】
For example, Given height = [2,1,5,6,2,3], return 10. 解题思路: 参考Problem H: Largest Rectangle in a Hist ...
- LeetCode 84. 柱状图中最大的矩形(Largest Rectangle in Histogram)
84. 柱状图中最大的矩形 84. Largest Rectangle in Histogram
- 刷题84. Largest Rectangle in Histogram
一.题目说明 题目84. Largest Rectangle in Histogram,给定n个非负整数(每个柱子宽度为1)形成柱状图,求该图的最大面积.题目难度是Hard! 二.我的解答 这是一个 ...
- 【LeetCode】84. Largest Rectangle in Histogram
Largest Rectangle in Histogram Given n non-negative integers representing the histogram's bar height ...
随机推荐
- maven 之 web.xml 头设置错误问题
1.一般开发工具创建web.xml的时候会默认添加web.xml头,而有些插件(例如maven相关插件)默认添加的为 版本和你的开发工具Project facets(项目特性)中设置不同.那么就会导致 ...
- phpcms调用子栏目名称/文章怎么操作
phpcms调用子栏目名称相对比较简单一些,也是用{pc:content}来调用,只是把action设置为category,catid如果为0的话是调用所有一级栏目,如果是其他数字的话,则调用相应栏目 ...
- 模块讲解----json与pickle模块的区别
1.在生产中,dumps和loads只进行一次,而且要用w把原来的数据冲掉,从而保证每次都是最新的. 2.虚拟机的快照,是每个快照都有一个文件,而不是全都不放在一起. 3.如果想生产好几个序列化,就生 ...
- 给idea配置默认的java jdk
1. 2. 3.选择安装的jdk的路径. 4.
- SqoopFlume、Flume、HDFS之间比较
Sqoop Flume HDFS Sqoop用于从结构化数据源,例如,RDBMS导入数据 Flume 用于移动批量流数据到HDFS HDFS使用 Hadoop 生态系统存储数据的分布式文件系统 Sqo ...
- java中的重量级与轻量级概念
首先轻量级与重量级是一个相对的概念,主要是对应用框架使用方便性和所提供服务特性等方面做比较的. 比方说EJB就是一个重量级的框架,因为它对所编写的代码有限制,同时它也提供分布式等复杂的功能. 相比之下 ...
- centos配置jdk的环境变量
1.首先呢,centos下的JDK环境配置分两种情况,一直是root用户级别的jdk配置,另一种是其他用户组级别的配置.这里讲解的是root用户级别的配置. 我们已经下载解压好了jdk的目录.如下 2 ...
- Spark高级数据分析· 2数据分析
wget https://archive.ics.uci.edu/ml/machine-learning-databases/00210/donation.zip 数据清洗 cd /Users/eri ...
- 20145324 Java实验四
在IDEA上操作 由于不会创建安卓模拟器失败 选择老师给的插件 成功 实验总结 开始开发安卓,感觉更难了,这次实验完全是看运气拼电脑的实验! 步骤 耗时 百分比 需求分析 10m 17% 设计 20m ...
- linux中断的下半部机制
一.中断处理为什么要下半部?Linux在中断处理中间中断处理分了上半部和下半部,目的就是提高系统的响应能力和并发能力.通俗一点来讲:当一个中断产生,调用该中断对应的处理程序(上半部)然后告诉系统,对应 ...