day42-数据结构力扣

42. 接雨水

题目链接 42. 接雨水 - 力扣(LeetCode)

思路

按照这个方向来计算雨水

还是采用单调栈的方法求解

只有凹下去的地方才能接水 也就是:中间低,左右两边高,才能存水。

单调栈怎么用?

  1. 栈存下标 ,保持栈内高度单调递减

  2. 遇到一个比栈顶高的柱子 → 说明形成凹槽,可以接水!

  3. 弹出栈顶,这个位置就是底部

  4. 新栈顶 = 左边界 ,当前元素 = 右边界

  5. 接水量 = 宽度 × (左右边界较小值 - 底部高度)

公式

雨水宽度 = 当前下标 - 新栈顶下标 - 1

高度 = min(左高, 右高) - 底部高度

总雨水量 += 宽度 × 高度

这里画了一次,栈里面存的是下标。30比10大,10的下标3弹出,下标2是新的栈顶元素

然后右边是计算公式伪代码,h,w计算公式可以直接看下面的提交,stack[-1]可能好理解一些

提交

python 复制代码
class Solution:
    def trap(self, height: List[int]) -> int:
        stack = []  # 存下标,保持高度递减
        res = 0
        n = len(height)
        
        for i in range(n):
            # 当前高度 > 栈顶高度 → 可以接水
            while stack and height[i] > height[stack[-1]]:
                # 凹槽底部
                bottom = stack.pop()
                if not stack:
                    break
                
                # 计算宽和高
                w = i - stack[-1] - 1
                h = min(height[i], height[stack[-1]]) - height[bottom]
                
                res += w * h
            
            stack.append(i)
        
        return res

84. 柱状图中最大的矩形

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

思路

跟上题差不多,只是递增

找到这个柱子,左边第一个比他小的,右边第一个比他小的

宽就是这个柱子可以拓展的宽度

高就是这个柱子自己的高度

提交

python 复制代码
class Solution:
    def largestRectangleArea(self, heights: List[int]) -> int:
        stack = []  # 存下标,高度递增
        max_area = 0
        n = len(heights)
        
        for i in range(n):
            # 当前高度 < 栈顶高度 → 栈顶找到右边界
            while stack and heights[i] < heights[stack[-1]]:
                # 弹出:作为矩形高度
                h_idx = stack.pop()
                h = heights[h_idx]
                
                # 左边界:栈空则为 -1,否则为新栈顶
                left = stack[-1] if stack else -1
                # 宽度
                w = i - left - 1
                # 面积
                max_area = max(max_area, h * w)
            
            stack.append(i)
        
        # 处理栈中剩余元素(右边界 = n)
        while stack:
            h_idx = stack.pop()
            h = heights[h_idx]
            left = stack[-1] if stack else -1
            w = n - left - 1
            max_area = max(max_area, h * w)
        
        return max_area
相关推荐
风筝在晴天搁浅1 小时前
阿里淘天/京东 CodeTop LeetCode103.二叉树的锯齿形层序遍历
数据结构
郝学胜-神的一滴2 小时前
干货版《算法导论》03:动态数组 × 链表的极致平衡艺术
java·数据结构·c++·python·算法·链表
图码3 小时前
最大子数组和问题:从暴力到Kadane算法的优雅蜕变
数据结构·算法·动态规划·柔性数组
庞轩px3 小时前
第一篇:Redis数据结构底层——String、List、Hash、Set、ZSet各自用什么实现的?
数据结构·redis·list·set·hash·string·zset
qq_296553273 小时前
[特殊字符] 数组中的递增三元组:O(n) 时间高效查找,面试必考!
数据结构·算法·面试·职场和发展·组合模式·柔性数组
今儿敲了吗3 小时前
链表篇(一)——合并两个有序链表
数据结构·笔记·算法·链表
y = xⁿ3 小时前
20天速通LeetCodeday11:二叉树进阶
数据结构·算法
大都督会赢的3 小时前
数据结构(1)--顺序表
c语言·数据结构·学习·指针
牢姐与蒯4 小时前
c++数据结构之AVL树
数据结构