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
相关推荐
Darling噜啦啦2 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
小小工匠3 天前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化
玖玥拾3 天前
C/C++ 数据结构(七)栈、容器适配器
c语言·数据结构·c++··容器适配器
Qres8213 天前
算法复键——树状数组
数据结构·算法
牛油果子哥q3 天前
并查集(DSU)超精讲,路径压缩、按秩合并、万能模板、连通性判定、最小生成树与刷题实战全解
数据结构·c++·最小生成树·并查集
凌波粒3 天前
LeetCode--491.递增子序列(回溯算法)
数据结构·算法·leetcode
WL学习笔记3 天前
单项不带头不循环链表
数据结构·链表
小糯米6013 天前
JS 数组
数据结构·算法·排序算法
小欣加油3 天前
leetcode3612 用特殊操作处理字符串I
数据结构·c++·算法·leetcode·职场和发展
凌波粒3 天前
LeetCode--90.子集II(回溯算法)
数据结构·算法·leetcode