当前位置: 首页 > news >正文

代码随想录Day51 完结篇 LeetCode T84 柱状图的最大矩形

前言

今天代码随想录一刷也告一段落了,没想到我居然坚持下来了,一节都没有落下,学习到了很多种不同的解题思路,也和大家一块交流了很多,哈哈也许不久以后我还得再次二刷代码随想录,希望这一系列的题解能给大家带来帮助,如想要系统学习,请参照代码随想录网站的题解以及b站的配套视频

这里给大家放上直达链接

1.随想录网站

代码随想录 (programmercarl.com)

2.b站讲解视频

代码随想录-哔哩哔哩_Bilibili

LeetCode T84  柱状图的最大矩形

题目链接:84. 柱状图中最大的矩形 - 力扣(LeetCode)

题目思路:

废话不多说,最后一天,打起十二分的精神

这题其实和上一题的接雨水问题有着异曲同工之妙

这一题其实就是接雨水的反面,接雨水是找凹槽,这里其实是凸起,我们需要找到左右两边比目前遍历元素小的元素,同样的思路,两者作差-1得到宽,高就是中间元素在数组中的值

唯一的难点就是在原数组两边得加上两个0,因为如果这里数组是按照升序排列的,这里我们这个方式就保持了一直递减,没有大于的情况来操作,如果我们在两边加上两个0其实就保证了两边的元素都可以处理到,无论是升序还是降序排列的数组都能够得到很好的处理

升序:保持递减无法处理

降序:一直处理无法达到栈内有两个元素的情况,最后只会是空栈.

题目代码:

class Solution {public int largestRectangleArea(int[] heights) {int result = 0;Stack<Integer> st = new Stack<>();int[] res = new int[heights.length+2];res[0] = 0;res[res.length-1] = 0;for(int i = 1;i<heights.length+1;i++){res[i] = heights[i-1];}st.push(0);for(int i = 1;i<res.length;i++){if(res[i]>=res[st.peek()]){st.push(i);}else{while(!st.isEmpty() && res[i]<res[st.peek()]){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;}
}

http://www.lryc.cn/news/239318.html

相关文章:

  • 对接苹果支付退款退单接口
  • 合肥中科深谷嵌入式项目实战——基于ARM语音识别的智能家居系统(三)
  • Web前端—移动Web第四天(vw适配方案、vw和vh的基本使用、综合案例-酷我音乐)
  • 报错注入 [极客大挑战 2019]HardSQL1
  • 【MATLAB源码-第83期】基于matlab的MIMO中V-BALST结构ZF和MMSE检测算法性能误码率对比。
  • Android13 新增 Stable AIDL接口
  • Postman API Enterprise 10.18.1 Crack
  • 电脑内存升级
  • ExcelBDD PHP Guideline
  • C++静态链接库的生成以及使用
  • 【2024系统架构设计】 系统架构设计师第二版-未来信息综合技术
  • JavaFX修改软件图标
  • Linux ps -ef|grep去除 grep --color=auto信息
  • jQuery的学习(一篇文章齐全)
  • 注塑行业各类业务流程图(系统化)
  • Android Studio 安装及使用
  • 计算机网络的OSI七层模型
  • 如何一次性解压多个文件
  • 类和对象学习笔记
  • Linux程序之可变参数选项那些事!
  • 【1day】泛微e-office OA系统user_page接口未授权访问漏洞学习
  • Midjourney绘画提示词Prompt参考教程
  • Altium Designer学习笔记6
  • 【问题解决】Maven密码加密
  • vue3基于vite打包
  • 前端使用JWT时无法获取Authorization请求头
  • postman定义公共函数这样写,测试组长直呼牛逼!!!
  • 单元测试实战(六)其它
  • jmeter 主从配置
  • 4