今天代码随想录一刷也告一段落了,没想到我居然坚持下来了,一节都没有落下,学习到了很多种不同的解题思路,也和大家一块交流了很多,哈哈也许不久以后我还得再次二刷代码随想录,希望这一系列的题解能给大家带来帮助,如想要系统学习,请参照代码随想录网站的题解以及b站的配套视频
这里给大家放上直达链接
1.随想录网站
2.b站讲解视频
题目链接:84. 柱状图中最大的矩形 - 力扣(LeetCode)


废话不多说,最后一天,打起十二分的精神
这题其实和上一题的接雨水问题有着异曲同工之妙
这一题其实就是接雨水的反面,接雨水是找凹槽,这里其实是凸起,我们需要找到左右两边比目前遍历元素小的元素,同样的思路,两者作差-1得到宽,高就是中间元素在数组中的值
唯一的难点就是在原数组两边得加上两个0,因为如果这里数组是按照升序排列的,这里我们这个方式就保持了一直递减,没有大于的情况来操作,如果我们在两边加上两个0其实就保证了两边的元素都可以处理到,无论是升序还是降序排列的数组都能够得到很好的处理
升序:保持递减无法处理
降序:一直处理无法达到栈内有两个元素的情况,最后只会是空栈.
- class Solution {
- public int largestRectangleArea(int[] heights) {
- int result = 0;
- Stack
st = new Stack<>(); - int[] res = new int[heights.length+2];
- res[0] = 0;
- res[res.length-1] = 0;
- for(int i = 1;i
1;i++){ - res[i] = heights[i-1];
- }
- st.push(0);
- for(int i = 1;i
- if(res[i]>=res[st.peek()]){
- st.push(i);
- }else{
- while(!st.isEmpty() && res[i]
- int tmp = st.peek();
- st.pop();
- int left = st.peek();
- int w = i-left-1;
- int h = res[tmp];
- result = Math.max(result,h*w);
-
- }
- st.push(i);
- }
-
- }
- return result;
- }
- }
-
相关阅读:
5-羧基荧光素标记Fe3O4四氧化三铁纳米粒5-PEG-FAM-PEG-Fe3O4
ElasticSearch学习笔记(一)es初体验
《计算机体系结构量化研究方法第六版》1.3 计算机体系结构的定义
安卓开发Android studio学习笔记14:用户注册登录(案例演示)
Chrome谷歌浏览器加载ActiveX控件之allWebDesktop控件介绍
【状态估计】将变压器和LSTM与卡尔曼滤波器结合到EM算法中进行状态估计(Python代码实现)
简单的介绍一下:柔性数组
电力系统潮流计算(牛顿-拉夫逊法、高斯-赛德尔法、快速解耦法)【6节点 9节点 14节点 26节点 30节点 57节点】(Matlab代码实现)
一起来学nginx(一)
向毕业妥协系列之机器学习笔记:监督学习-回归与分类(一)
-
原文地址:https://blog.csdn.net/qiuqiushuibx/article/details/134534820