LeetCode:84. Largest Rectangle in Histogram - Python

189 篇文章 3 订阅
151 篇文章 2 订阅
84. 柱状图中最大的矩形

问题描述:

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

求在该柱状图中,能够勾勒出来的矩形的最大面积
在这里插入图片描述
以上是柱状图的示例,其中每个柱子的宽度为1,给定的高度为[2,1,5,6,2,3]
在这里插入图片描述
图中阴影部分为所能勾勒出的最大矩形面积,其面积为10个单位。

问题分析:

首先说一下题目,我感觉这才是好题目,感觉是小巧玲珑。自己用的暴力的方法不太好呀,参考了评论区的优秀代码,现在总结一下:

(1)思想,用栈

(2)假设这些柱子都是上升的,也就是递增的。很显然,这个矩形的高度要受到左边界柱子的限制。所以现在:

  1. 可以用栈,只要是递增状态的柱子就统统入栈(入下标索引,为了方便得到矩形的宽度)。

  2. 现在如果遇到一个比当前要的柱子,怎么办?那些现在就出栈,以当前位置为右边界,出栈的柱子为高,从右至左循环求出每个矩形的面积,并更新最大面积。

  3. 直到栈顶的柱子小于当前柱子,然后进行下一步。

(3)如果都是递增的怎么办?可以在数组最后面加一个0作为结束的标志。

Python3实现:

class Solution:
    def largestRectangleArea(self, heights: 'List[int]') -> 'int':
        heights.append(0)  # 末尾加一个 0 或者比较 0小的
        stack = [-1]
        res = 0
        for i in range(len(heights)):
            while heights[i] < heights[stack[-1]]:
                h = heights[stack.pop()]  # 高
                w = i - stack[-1] - 1  # 宽
                res = max(res, h * w)  # 更新最大面积
            stack.append(i)  # 入栈
        heights.pop()  # 把0再删除
        return res


if __name__ == '__main__':
    solu = Solution()
    heights = [2, 1, 5, 6, 2, 3]
    heights = [1, 2, 3, 4, 5, 6]
    print(solu.largestRectangleArea(heights))

声明: 总结学习,有问题或不当之处,可以批评指正哦,谢谢。

题目链接参考链接

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
给定一个整数数组 nums 和一个目标值 target,要求在数组中找出两个数的和等于目标值,并返回这两个数的索引。 思路1:暴力法 最简单的思路是使用两层循环遍历数组的所有组合,判断两个数的和是否等于目标值。如果等于目标值,则返回这两个数的索引。 此方法的时间复杂度为O(n^2),空间复杂度为O(1)。 思路2:哈希表 为了优化时间复杂度,可以使用哈希表来存储数组中的元素和对应的索引。遍历数组,对于每个元素nums[i],我们可以通过计算target - nums[i]的值,查找哈希表中是否存在这个差值。 如果存在,则说明找到了两个数的和等于目标值,返回它们的索引。如果不存在,将当前元素nums[i]和它的索引存入哈希表中。 此方法的时间复杂度为O(n),空间复杂度为O(n)。 思路3:双指针 如果数组已经排序,可以使用双指针的方法来求解。假设数组从小到大排序,定义左指针left指向数组的第一个元素,右指针right指向数组的最后一个元素。 如果当前两个指针指向的数的和等于目标值,则返回它们的索引。如果和小于目标值,则将左指针右移一位,使得和增大;如果和大于目标值,则将右指针左移一位,使得和减小。 继续移动指针,直到找到两个数的和等于目标值或者左指针超过了右指针。 此方法的时间复杂度为O(nlogn),空间复杂度为O(1)。 以上三种方法都可以解决问题,选择合适的方法取决于具体的应用场景和要求。如果数组规模较小并且不需要考虑额外的空间使用,则暴力法是最简单的方法。如果数组较大或者需要优化时间复杂度,则哈希表或双指针方法更合适。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值