代码随想录算法训练营第60天 | 一刷结束篇 84.柱状图中最大的矩形

news2025/1/10 17:34:35

代码随想录系列文章目录

一刷总结篇


文章目录

  • 代码随想录系列文章目录
  • 84.柱状图中最大的矩形
    • dp 普通思路
    • 单调栈
  • 一刷总结篇


84.柱状图中最大的矩形

题目链接
这道题和接雨水是两个相似的题,相辅相成的那种,双指针是过不了力扣的会超时,所以我也不写了

dp 普通思路

先说一下思路,计算公式是什么捏?遍历每一块矩形,它对应的最大面积就是heights[i] * (左边第一个小于它高度的坐标 - 右边第一个小于它高度的坐标 - 1)
然后动态更新一下这个res就行了

难就难在本题要记录每个柱子 左边第一个小于该柱子的下标,而不是左边第一个小于该柱子的高度。

所以需要循环查找,也就是下面在寻找的过程中使用了while,详细请看下面注释

def largestRectangleArea(self, heights: List[int]) -> int:
        n = len(heights)
        dpl, dpr = [0] * n, [0] * n
        res = 0

        # 记录每个柱子的左侧第一个矮一级的柱子的下标
        dpl[0] = -1
        for i in range(1, n):
            temp = i-1
            #当左边持续较高,尝试再左边的,直到找到第一个矮一点的柱子
            while temp >= 0 and heights[temp] >= heights[i]:
                temp = dpl[temp]
            #跳出这个循环说明有可能找到了
            dpl[i] = temp #把下标赋给当前的dp[i]
        
        dpr[n-1] = n
        for i in range(n-2, -1, -1):
            temp = i + 1
            while temp <= n-1 and heights[temp] >= heights[i]:
                temp = dpr[temp]
            dpr[i] = temp

        for i in range(n):
            area = heights[i] * (dpr[i] - dpl[i] -1)
            res = max(res, area)
        return res

单调栈

这道题和接雨水是呼应的,接雨水找的是两边第一个大于它高度的柱子,这道题是找两边第一个小于它高度的下标

这就导致在这题中单调栈的顺序是从大到小的

在这里插入图片描述
此时大家应该可以发现其实就是栈顶栈顶的下一个元素以及要入栈的三个元素组成了我们要求最大面积的高度和宽度

思路
单调栈的思路还是,当前遍历到的位置i,如果height[i] > height[stack[-1]], 我们直接入栈

如果说 height[i] == height[stack[-1]], 我们pop出那个,入栈新的,因为我们要的是坐标嘛

然后,遇到小于栈顶的情况的话,height[i] < height[stack[-1]], 我们开始更新我们的结果

怎么计算呢?还是老三样,栈顶作为mid坐标,是拿来用height[mid]作高度的,然后pop出来。此时的新栈顶作为leftidx, i 是rightidx,这俩是用来做宽度的

与接雨水不同的是,这道题的首尾两个柱子都可以作为核心柱子,做最大面积的尝试

所以为此所做的操作是,输入数组首尾各补上一个0
但是遍历的时候,还是栈先入0, 然后i从1到 len(new_heights), 这样才能确保边缘两根做主心骨的情况

def largestRectangleArea(self, heights: List[int]) -> int:
        stack = [0]
        res = 0
        heights = [0] + heights + [0]
        
        for i in range(1, len(heights)):
            if heights[i] > heights[stack[-1]]:
                stack.append(i)
            elif heights[i] == heights[stack[-1]]:
                stack.pop()
                stack.append(i)
            else:
                while stack and heights[i] < heights[stack[-1]]:
                    mid = stack[-1]
                    stack.pop()
                    if stack:
                        h = heights[mid]
                        w = i - stack[-1] - 1
                        res = max(res, h*w)
                stack.append(i)
        return res

一刷总结篇

刚到日本的时候,我也是想着秋招要试试水,所以刷题也没停下。
当时九月初我是想着复习一下dp,于是就是照着代码随想录的dp篇章开始做。大概做了几天后,看见朋友圈卡哥发的代码随想录算法训练营,大家一起抱团取暖。于是我毫不犹豫的报名参加了。

两个月以来,不管多忙,不管有多懒,每天我都按时的把今天该做的任务完成了。实事求是的说,刷代码随想录还是一件很愉快的事情。把一个复杂的题,用逻辑疏通每一个关节,明白其中的难点和用到的数据结构,是一件很有成就感的小事。

希望接下来,我能更有勇气去面对前方的困难(我一直没上岸哈哈),希望我能坚定自己选择的路,人生能选择去做自己的喜欢的事,活的比任何人都要自由。
就像YOASAOBI-群青中描述的那样,能够做自己喜欢的事情,所获得的不止是乐趣而已。

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

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

相关文章

pandas提取键值对(json和非json格式)

&#xff08;欢迎大家关注我的公众号“机器学习面试基地”&#xff0c;之后将在公众号上持续记录本人从非科班转到算法路上的学习心得、笔经面经、心得体会。未来的重点也会主要放在机器学习面试上&#xff01;&#xff09; 最近工作中需要解析一些有模型输入输出信息的csv日志…

SpringBoot+Mybaits搭建通用管理系统实例七:访问接口Api层功能实现

一、本章内容 系统api接口层实现,实现系统对外接口相应功能定义及实现,并通过Swagger实现接口文档的自动生成。 完整课程地址 二、开发视频 SpringBoot+Mybaits搭建通用管理系统实例二:api层实现 三、代码实现 使用基类的方式实现各方法接口的抽象实现,使用泛型的方式指定具…

linux上配置jdk和maven环境 (deepin适用)

前言 安装那些&#xff0c;就不说了&#xff0c;应该大家都下好才来配置的&#xff0c;下载安装的话&#xff0c;直接解压到一个目录就好&#xff0c;给个链接给你 jdk8下载链接&#xff1a; https://www.oracle.com/java/technologies/javase/javase-jdk8-downloads.html 命…

Docker Buildkit(新增 --mount、--security、--network 等特性)

BuildKit是Docker官方社区推出的下一代镜像构建神器。 可以更加快速&#xff0c;有效&#xff0c;安全地构建docker 镜像&#xff0c;自 docker v18.06 版本起已经集成了该组件。 Buildkit 是下一代 docker 构建组件&#xff0c;拥有众多特性&#xff1a; 自动垃圾收集可扩展…

静态WEB容器镜像最小化实践

在现代的B/S架构应用中&#xff0c;我们会做前后端分离&#xff0c;某些前端Web服务会将编译完成的静态文件放到一个web服务器进行部署。例如&#xff0c;我的博客也是基于Hugo编译的静态文件来进行部署的。 那在容器化部署模式下&#xff0c;我们需要基于一个web服务的基础容…

js:什么是编译时和运行时

编译时 源代码编译为机器可执行的二进制码。 编译过程中一般会识别你代码中的语法错误等问题&#xff0c;这个错误就叫编译时错误&#xff0c;做的一些检查也叫做编译时类型检查或者静态类型检查&#xff0c;因为静态就意味着代码还没有放到内存里去运行&#xff0c;只是把代…

九.STM32F030C8T6 MCU开发之电源掉电数据保存案例

九.STM32F030C8T6 MCU开发之电源掉电数据保存案例 0.总体功能概述 使用STD库–en.stm32f0_stdperiph_lib_v1.6.0。 1.掉电数据保存背景 掉电保存数据的时间内 电源稳定。也就是数据保存时间要尽量短,电源稳定要尽量长。 第一种,采用备用电池的方法来实现,增加了电池和更…

DFS搜索和输出所有路径

文章目录1、DFS搜所有路径2、用栈记录和输出路径3、例题3.1 C代码3.2 Python代码4、真题4.1 C代码4.2 Python代码2022.12将出版蓝桥杯大赛用书《蓝桥杯大赛-程序设计竞赛专题挑战教程》&#xff0c;作者&#xff1a;蓝桥杯组委会、罗勇军。   这本书解析了蓝桥杯大赛的常见考…

PLC学习笔记(二):PLC结构(1)

目录&#xff1a; PLC学习笔记&#xff08;一&#xff09;&#xff1a;概述 PLC学习笔记&#xff08;二&#xff09;&#xff1a;PLC结构&#xff08;1&#xff09; PLC学习笔记&#xff08;三&#xff09;&#xff1a;PLC结构&#xff08;2&#xff09; &#x1f981;&…

嵌入式FreeRTOS学习十一,深入理解任务调度机制

一.任务调度机制 可抢占&#xff1a;高优先级的任务先运行时间片轮转&#xff1a;同优先级的任务轮流执行空闲任务礼让&#xff1a;如果有同是优先级为0的其他就绪任务&#xff0c;空闲任务主动放弃一次运行机会函数调用vTaskDelay( xDelay5ms )可以主动放弃任务执行&#xff…

大学物理·第8章【电磁感应、电磁场】

from now on, 以后的篇幅我都不会写太多了。因为效果也不一定有&#xff0c;还很浪费时间。 感应电动势 那个奥特曼变身器的符号是 磁链 看看划线公式即可 动生电动势&#xff1a;dξ vB dl 例 如果&#xff0c;到时候复习的时候觉得简单的话&#xff0c;就删掉好了 自感、互…

【HTML5】登录页面制作简易版

刚开始学习Java。文件的命名&#xff0c;讲道理应该以英文为主&#xff0c;但是英语又不好&#xff0c;所以只好用拼音&#xff0c;最痛苦的应该算是那些英语又不好&#xff0c;又想秀一下的程序员&#xff0c;一半英语一半拼音&#xff0c;如mainFangFa~~~你说看了糟心不糟心。…

山东大学线性代数-1-矩阵-1

目录 1.2 几种特殊的矩阵 1.2.1 方阵 1.2.2 零矩阵 1.2.3 对角矩阵 1.2.4 单位矩阵 1.2.5 数量矩阵 1.2.6 三角阵 1.2.7 梯形阵 1.3 矩阵的运算&#xff08;一&#xff09; 1.3.1 相等 1.3.2 加、减法 1.3.3 数乘 1.3.4 矩阵的乘法 1.4 矩阵的运算&#xff08;二&#x…

SpringBoot SpringBoot 开发实用篇 4 数据层解决方案 4.18 查询文档

SpringBoot 【黑马程序员SpringBoot2全套视频教程&#xff0c;springboot零基础到项目实战&#xff08;spring boot2完整版&#xff09;】 SpringBoot 开发实用篇 文章目录SpringBootSpringBoot 开发实用篇4 数据层解决方案4.18 查询文档4.18.1 查询文档4.18.2 小结4.18.3 总…

山东大学线性代数-3-n维向量

目录 3.1 n维向量及其线性运算 3.1.1 n维向量的概念 3.1.2 向量的相等 3.1.3 n维向量的线性运算 3.1.4 线性组合 3.1.5 向量组的等价 3.2 向量组的线性相关性 3.2.1 线性相关性的定义 3.2.2 特殊情形的线性相关性 3.3 相关性的判定及有关重要结论 3.3.1 线性相关与…

[MQ] SpringBoot使用直连交换机Direct Exchange

✨✨个人主页:沫洺的主页 &#x1f4da;&#x1f4da;系列专栏: &#x1f4d6; JavaWeb专栏&#x1f4d6; JavaSE专栏 &#x1f4d6; Java基础专栏&#x1f4d6;vue3专栏 &#x1f4d6;MyBatis专栏&#x1f4d6;Spring专栏&#x1f4d6;SpringMVC专栏&#x1f4d6;SpringBoot专…

Bootstrap-栅格实例(二)

栅格实例 进入官网 选择3.0的中文文档&#xff1a; 选择组件&#xff1a; 选择缩放图&#xff1a; 选择这个&#xff0c;复制代码&#xff1a; 把代码拷贝到&#xff0c;新创建的模板固定container里面&#xff1a; 删除靠过来的多余的row&#xff1a; 修改div的calss&…

【信息奥赛实训】Week1——STL 与基础数据结构专题训练

【信息奥赛实训】Week1-Lab-STL 作者&#xff5c;Rickyの水果摊 时间&#xff5c;2022年11月20日 实训概要 实训专题 STL 与基础数据结构专题训练 实训目的 掌握STL常用的算法、容器、容器适配器的使用方法。能够利用STL的算法、容器、容器适配器求解问题。 题目列表 A&…

HTML小游戏9 —— 潜行游戏《侠盗罗宾汉》(附完整源码)

&#x1f482; 网站推荐:【神级源码资源网】【摸鱼小游戏】&#x1f91f; 风趣幽默的前端学习课程&#xff1a;&#x1f449;28个案例趣学前端&#x1f485; 想寻找共同学习交流、摸鱼划水的小伙伴&#xff0c;请点击【摸鱼学习交流群】&#x1f4ac; 免费且实用的计算机相关知…

紫外线杀菌器

一、概述 紫外线杀菌器是利用波长为225-275nm的紫外线对微生物的杀灭而使水中菌类得以净化。当水流经消毒仪时&#xff0c;高强度杀菌作用的紫外线即将水中细菌杀灭。本产品彻底解决了饮用水二次污染细菌超标问题&#xff0c;同时也适用于饮料、食品、游泳池等用水的消毒处理。…