首页 > 编程语言 >代码随想训练营第六十天(Python)| 84. 柱状图中最大的矩形

代码随想训练营第六十天(Python)| 84. 柱状图中最大的矩形

时间:2023-12-10 14:22:26浏览次数:57  
标签:tmp temp min Python res heights 柱状图 随想 stack

84. 柱状图中最大的矩形
1、双指针

class Solution:
    def largestRectangleArea(self, heights: List[int]) -> int:
        n = len(heights)
        # 左右第一个小于 i 的下标
        min_l, min_r = [0] * n, [0] * n

        res = 0

        min_l[0] = -1
        for i in range(1, n):
            temp = i-1
            while temp >= 0 and heights[temp] >= heights[i]:
                temp = min_l[temp]
            min_l[i] = temp

        min_r[n-1] = n
        for i in range(n-2, -1, -1):
            tmp = i + 1
            while tmp < n and heights[tmp] >= heights[i]:
                tmp = min_r[tmp]
            min_r[i] = tmp

        for i in range(n):
            area = heights[i] * (min_r[i] - min_l[i] - 1)
            res = max(area, res)

        return res

2、单调栈

        # 找到左右第一个小于下标为 i 的
        heights.insert(0, 0)
        heights.append(0)
        n = len(heights)
        stack = []
        res = 0
        for i in range(n):
            while stack and heights[i] < heights[stack[-1]]:
                mid_h = heights[stack.pop()]
                if stack:
                    area = (i - stack[-1] - 1) * mid_h
                    res = max(area, res)
            stack.append(i)
        return res

标签:tmp,temp,min,Python,res,heights,柱状图,随想,stack
From: https://www.cnblogs.com/yixff/p/17892598.html

相关文章

  • #yyds干货盘点#深入了解Python类与面向对象编程
    类与对象的概念1.什么是类?类是一种用户自定义的数据类型,用于描述对象的属性和行为。它是对象的模板,定义了对象的结构。2.创建类使用class关键字来创建类。示范如何定义一个类,包括类名、属性和方法的定义。classDog:def__init__(self,name,breed):self.name=nam......
  • python算法
    目录: 回溯算法:  回溯算法:一般模型:results=[]defbacktrack(路径,选择列表):passif路径结束,满足约束条件:results.append(路径)#保存结果return#注意,返回到上一个分支,而不是返回结果,退出回溯if路径结束,不满足约束条件:......
  • Python进阶补充
    变量的进阶引用的概念:1、定义变量的时候,变量和数据,都会在内存中开辟空间2、变量所对应的内存空间中存储的是数据所在内存的地址3、变量中保存数据地址的操作,就称为引用4、Python中所有数据的传递,都是引用,即“地址”5、只有赋......
  • Python神器!WEB自动化测试集成工具 DrissionPage
    Python神器!WEB自动化测试集成工具DrissionPage 一、前言用requests做数据采集面对要登录的网站时,要分析数据包、JS源码,构造复杂的请求,往往还要应付验证码、JS混淆、签名参数等反爬手段,门槛较高。若数据是由JS计算生成的,还须重现计算过程,体验不好,开发效率不高。使用浏览器,......
  • Python从入门到实践practice6
    1文件路径2读取文件pathlib函数path3写文件4异常类型5捕捉异常try/except语句'''文件路径:绝对路径和相对路径绝对路径是从根路径开始根路径:类Unix操作系统(一个根路径)/开始Windows操作系统(多个盘多个分区)c:\D:\绝对路径类Unix操作系统/......
  • python语言在web上的应用:如何节省服务器资源?
    背景介绍在web开发中的应用广泛在web开发中的应用广泛。随着互联网的发展,web应用越来越普遍,而Python作为一种简洁、高效的编程语言,被广泛应用于web开发领域。Python提供了丰富的库和框架,如Django、Flask等,使开发人员能够快速搭建功能强大的web应用。同时,Python还具有良好的可扩展性......
  • Win10操作系统安装Python
    1Python解释器下载1.1安装环境Windows10专业工作站版22H2python-3.9.6-amd64.exe1.2下载地址Python官网:https://www.python.org/Python镜像:https://registry.npmmirror.com/binary.html?path=python/3.9.6/2Python解释器安装2.1InstallPython3.9.6(64-bit)界面......
  • python3使用pandas备份mysql数据表
    操作系统:CentOS7.6_x64Python版本:3.9.12MySQL版本:5.7.38日常开发过程中,会遇到mysql数据表的备份需求,需要针对单独的数据表进行备份并定时清理数据。今天记录下python3如何使用pandas进行mysql数据表的备份,我将从以下几个方面进行展开: 数据表备份逻辑描述 使用的相关......
  • Python 时间处理与时区转换:深入探究 datetime、time 模块与 pytz 库的功能与应用
    Python中的datetime和time模块为处理时间和日期提供了强大的功能。这些模块不仅支持时间和日期的操作,还能进行时间戳的转换、时区操作等。在本文中,我们将深入介绍这些模块的用法和实际示例。1.datetime模块:处理日期和时间datetime模块是Python标准库中用于处理日期和时间......
  • 计分牌Scoreboarding代码实现(Python)
    代码地址:Scoreboarding:计算机体系结构作业——计分板模拟(gitee.com)简介此代码为高级计算机体系结构作业——计分板模拟器,使用python实现;模拟的CPU只有四个阶段,分别是发出指令(Issue)、读操作数(ReadOperator,RO)、执行计算(ExecuteComputation,EC)、写结果(WriteResult,WR)......