LeetCode 84. 柱状图中最大的矩形

84. 柱状图中最大的矩形

给定 n 个非负整数,用来表示柱状图中各个柱子的高度。每个柱子彼此相邻,且宽度为 1 。

求在该柱状图中,能够勾勒出来的矩形的最大面积。

示例 1:

输入:heights = [2,1,5,6,2,3]

输出:10

解释:最大的矩形为图中红色区域,面积为 10

示例 2:

输入: heights = [2,4]

输出: 4

提示:

  • 1 <= heights.length <=10^5
  • 0 <= heights[i] <= 10^4

解法思路(参考官方题解及视频讲解):

1、暴力1 O(n^3)

for i -> 0, nfor j -> i, n(i, j) -> 最小高度,areaupdate max-area

2、暴力2 O(n^2)

for i -> 0, n:找到 left bound, right boundarea = height[i] * (right - left)update max-area

3、Stack

4、优化 Stack,加哨兵元素

 法一(超时):

class Solution {public int largestRectangleArea(int[] heights) {// Time: O(n^3)// Space: O(1)int maxArea = 0;for (int i = 0; i < heights.length; i++) {for (int j = i; j < heights.length; j++) {int minHeight = Integer.MAX_VALUE;for (int k = i; k <= j; k++) {minHeight = Math.min(minHeight, heights[k]);}maxArea = Math.max(maxArea, minHeight * (j - i + 1));}}return maxArea;}
}

法二(超时):

class Solution {public int largestRectangleArea(int[] heights) {// Time: O(n^2)// Space: O(1)int maxArea = 0;for (int i = 0; i < heights.length; i++) {int minHeight = Integer.MAX_VALUE;for (int j = i; j < heights.length; j++) {minHeight = Math.min(minHeight, heights[j]);maxArea = Math.max(maxArea, minHeight * (j - i + 1));}}return maxArea;}
}

法三:

class Solution {public int largestRectangleArea(int[] heights) {// Stack 空间换时间// 特殊情况1:遍历完成后,栈内元素出栈时一定可以扩展到数组的末尾// 特殊情况2:弹出栈顶后栈为空,一定可以扩散到数组最左边// 特殊情况3:栈中存在高度相等的元素,出栈// Time: O(n)// Space: O(n)int len = heights.length;if (len == 0) return 0;if (len == 1) return heights[0];int maxArea = 0;Deque<Integer> stack = new ArrayDeque<>();for (int i = 0; i < len; i++) {// 当前元素的高度严格小于栈顶元素的高度时,出栈while (!stack.isEmpty() && heights[i] < heights[stack.peekLast()]) {int height = heights[stack.removeLast()];// 特殊情况3:栈中存在高度相等的元素,出栈while (!stack.isEmpty() && heights[stack.peekLast()] == height) {stack.removeLast();}// 特殊情况2:弹出栈顶后栈为空,一定可以扩散到数组最左边int width = stack.isEmpty() ? i : (i - stack.peekLast() - 1);maxArea = Math.max(maxArea, width * height);}stack.addLast(i);}// 弹出栈中所有元素while (!stack.isEmpty()) {int height = heights[stack.removeLast()];while (!stack.isEmpty() && heights[stack.peekLast()] == height) {stack.removeLast();}// 特殊情况1:遍历完成后,栈内元素出栈时一定可以扩展到数组的末尾int width = stack.isEmpty() ? len : (len - stack.peekLast() - 1);maxArea = Math.max(maxArea, width * height);}return maxArea;}
}

优化法三:

class Solution {public int largestRectangleArea(int[] heights) {// Stack(add Sentinel)// Time: O(N)// Space: O(N)int len = heights.length;if (len == 0) return 0;if (len == 1) return heights[0];int maxArea = 0;int[] newHeights = new int[len + 2];for (int i = 0; i < len; i++) {newHeights[i + 1] = heights[i];}len += 2;heights = newHeights;Deque<Integer> stack = new ArrayDeque<Integer>();stack.addLast(0);for (int i = 1; i < len; i++) {while (heights[stack.peekLast()] > heights[i]) {int height = heights[stack.removeLast()];int width = i - stack.peekLast() - 1;maxArea = Math.max(maxArea, width * height);}stack.addLast(i);}return maxArea;}
}

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/594041.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Spring-IOC综述

文章迁移自语雀。 怎么查看spring的文档 ioc综述 说到spring的ioc,其实就是控制反转,为啥需要控制反转呢,其实是为了功能的增强,如果不用spring, 我们直接使用工厂方法,静态工厂方法, 都是是可以获取到对象的,但是如果需求变了,我们在类的生成时,添加了很多信息,使用工厂就不…

【INTEL(ALTERA)】Arria V FPGA GPIO 引脚上的内部箝位二极管是否始终处于活动状态?

说明 当设备未通电或未配置设备时&#xff0c;英特尔 Arria V FPGA GPIO 引脚上的内部箝位二极管是否处于活动状态&#xff1f; 解决方法 根据 Arria V 器件手册&#xff1a;第 1 卷&#xff1a;设备接口和集成&#xff0c;片上钳位二极管功能通过 英特尔 Quartus Prime 软件…

【鸿蒙杂谈①】——鸿蒙基础介绍及应用领域

1.前言 小伙伴们大家好&#xff0c;最近被复习整的痛苦无比&#xff0c;所以今天咱们了解 一点轻松的东西&#xff0c;至于高并发就先放放吧。好了&#xff0c;废话不多说&#xff0c;咱们进入正题。 相信小伙伴们都已经看到了最近鸿蒙的势头了&#xff0c;那鸿蒙究竟是怎么发…

《Linux C编程实战》笔记:实现自己的myshell

ok&#xff0c;考完试成功复活 这次是自己的shell命令程序的示例 流程图&#xff1a; 关键函数 1.void print_prompt() 函数说明&#xff1a;这个函数打印myshell提示符&#xff0c;即“myshell$$”. 2.void get_input(char *buf) 函数说明&#xff1a;获得一条指令&#…

阿里云免费SSL证书有效期只有3个月?

阿里云免费SSL证书签发有效期从12个月缩短至3个月&#xff1a;尊敬的用户&#xff0c;根据供应商变更要求&#xff0c;免费证书&#xff08;默认证书&#xff09;的签发有效期将由12个月缩短至3个月。 免费证书&#xff08;升级证书&#xff09;的有效期不会改变。 没错&#…

Vue3-32-路由-重定向路由

什么是重定向 路由的重定向 &#xff1a;将匹配到的路由 【替换】 为另一个路由。 redirect : 重定向的关键字。 重定向的特点 1、重定向是路由的直接替换,路由的地址是直接改变的&#xff1b; 2、在没有子路由配置的情况下&#xff0c;重定向的路由可以省略 component 属性的配…

Langchain访问OpenAI ChatGPT API Account deactivated的另类方法,访问跳板机API

笔者曾经写过 ChatGPT OpenAI API请求限制 尝试解决 Account deactivated. Please contact us through our help center at help.openai.com if you need assistance. 结果如何&#xff1f; 没有啥用。目前发现一条曲线救国的方案。 1. 在官方 openai 库中使用 此处为最新Op…

【IC覆盖率】

覆盖率分享 1 覆盖率提高策略2 覆盖率类型2.1 代码覆盖率2.2 功能覆盖率2.3 Waive提高覆盖率 覆盖率是用于衡量设计的完备性&#xff0c;进行指导分析发现没覆盖到的盲区&#xff0c;通过修改约束或者追加定向case来提到覆盖率&#xff1b; 1 覆盖率提高策略 1.首先最先的是每…

全国计算机等级考试| 二级Python | 真题及解析(10)

一、选择题 1.要实现将实数型变量a的值保留三位小数,以下python可以实现的是( ) A.a%0.001 B.a//0.001 C.round(a,3) D.round(3,a) 2.在Python中要交换变量a和b中的值,应使用的语句组是( )。 A…

基于SpringBoot的医院档案管理系统设计与实现

文章目录 项目介绍主要功能截图:部分代码展示设计总结项目获取方式🍅 作者主页:超级无敌暴龙战士塔塔开 🍅 简介:Java领域优质创作者🏆、 简历模板、学习资料、面试题库【关注我,都给你】 🍅文末获取源码联系🍅 项目介绍 基于SpringBoot的医院档案管理系统设计与…

思科校园网搭建及配置综合小型实验

思科校园网搭建及配置综合小型实验 实验拓扑配置步骤配置聚合链路配置VTP&#xff0c;vlan域模板第一步 配置二层VLAN第二步 配置生成树第三步 配置相关IP地址第四步 配置DHCP及DHCP中继第五步 配置三层的网关冗余协议 双机热备及OSPF第六步 配置静态路由,NAT地址转换及其他配置…

[Verilog语言入门教程] Verilog 减法器 (半减器, 全减器, 加减共用)

依公知及经验整理,原创保护,禁止转载。 专栏 《元带你学Verilog》 <<<< 返回总目录 <<<< “逻辑设计是一门艺术,它需要创造力和想象力。” - 马克张伯伦(Mark Zwolinski) 减法器是数字电路中常见的组件,用于减去两个二进制数的和。 在Verilog中…

总结2023,展望2024

2023年是一个充满挑战和机遇的一年。全球范围内&#xff0c;人们继续努力应对新冠疫情的影响&#xff0c;各行各业都面临着巨大的变革和调整。在这个动荡的环境下&#xff0c;技术行业也经历了许多重要的发展和变革。 首先&#xff0c;人工智能在2023年取得了巨大的突破和应用…

面试经典150题(62-64)

leetcode 150道题 计划花两个月时候刷完&#xff0c;今天&#xff08;第三十天&#xff09;完成了3道(62-64)150&#xff1a; 62.&#xff08;226. 翻转二叉树&#xff09;题目描述&#xff1a; 给你一棵二叉树的根节点 root &#xff0c;翻转这棵二叉树&#xff0c;并返回其…

麒麟云增加计算节点

一、安装基座系统并配置好各项设置 追加的计算节点服务器&#xff0c;安装好系统&#xff0c;把主机名、网络网线&#xff08;网线要和其他网线插的位置一样&#xff09;、hosts这些配置好&#xff0c;在所有节点的/etc/hosts里面添加信息 在控制节点添加/kylincloud/multinod…

人工智能趋势报告解读:ai野蛮式生长的背后是机遇还是危机?

近期&#xff0c;Enterprise WordPress发布了生成式人工智能在营销中的应用程度的报告&#xff0c;这是一个人工智能迅猛发展的时代&#xff0c;目前人工智能已经广泛运用到内容创作等领域&#xff0c;可以预见的是人工智能及其扩展应用还将延伸到我们工作与生活中的方方面面。…

springboot自动配置原理

第一步启动类注解 第二步可以看到启动类注解组合了自动配置这个注解&#xff08;enableAutoConfiguration&#xff09; 第三步进入这个注解 可以看到里面导入了一个impotSelector这个自动配置的字节码 第四步点进去 可以看到实现了deferredImportSelector这个接口 并且在这个类…

C# 前端GET或POST传递的两种参数body和query的区别

当前端通过通过Get或Post进行HTTP请求时&#xff0c;有两种方式传递参数&#xff1a;通过请求体&#xff08;body&#xff09;和通过查询字符串&#xff08;query&#xff09;。 GET&#xff1a; GET方法用于从服务器获取资源&#xff0c;它只能通过查询字符串&#xff08;qu…

Rockchip平台Android应用预安装功能(基于Android13)

Rockchip平台Android应用预安装功能(基于Android13) 1. 预安装应用类型 Android上的应用预安装功能&#xff0c;主要是指配置产品时&#xff0c;根据厂商要求&#xff0c;将事先准备好的第三方应用预置进Android系统。预安装分为以下几种类型&#xff1a; 安装不可卸载应用安…

postfix配置tls加密

1.编译安装 编译安装openss【卸载原有openssl&#xff0c;然后下载新的安装&#xff0c;因为postfix需要新版本openssl】编译安装postfix,下面这行命令 make -f Makefile.init makefiles CCARGS"-DHAS_MYSQL -I/www/server/mysql/include -DUSE_SASL_AUTH -I/usr/include…