LeetCode-42. 接雨水

LeetCode-42. 接雨水

问题分析

从左往右遍历数组height,对于每个元素执行如下的单调栈操作:

若栈不为空,且栈顶元素的高度值小于当前元素的高度值,说明栈顶元素可以接雨水

  • 弹出栈顶元素,记为floor,表示当前接雨水区域底部的高度
  • 若此时栈为空,说明左边没有墙体,无法接雨水,跳出循环。
  • 否则,再取一个栈顶元素left,获取左墙的高度和下标
  • 根据已知信息,便可以获取以floor为底,以left作为左墙体,以当前元素为右墙体,构成区域所能截取的雨水量

上述流程执行完成后,此时栈顶元素的高度大于等于当前元素的高度,当前元素是潜在的左墙体,因此压入单调栈中。

程序代码

C++

cpp 复制代码
class Solution {
public:
    int trap(vector<int>& height) {
        // 存储下标
        stack<int> stk;
        int res = 0;
        for(int i = 0; i < height.size(); i++) {
            while( !stk.empty() && height[stk.top()] < height[i] ) {
                int floor = stk.top();
                stk.pop();
                // 边界情况:没有左墙
                if( stk.empty() )  break;
                // 获取左墙高度
                int left = stk.top();
                int curHeight = min(height[left],  height[i]) - height[floor];
                res += curHeight * (i - left - 1);
            }
            stk.push(i);
        }
        return res;
    }
};

Go

go 复制代码
func trap(height []int) int {
    stack := []int{}
    res := 0

    for i, h := range height {
        for len(stack) > 0 && height[stack[len(stack)-1]] < h {
            floor := stack[len(stack) - 1]
            stack = stack[:len(stack) - 1]
            if len(stack) == 0 {
                break;
            }
            left := stack[len(stack) - 1]
            curHeight := min(height[left], h) - height[floor]
            res += curHeight * (i - left - 1)
        }
        stack = append(stack, i)
    }
    return res
}

func min(a, b int) int {
    if a <= b {
        return a
    }
    return b
}
相关推荐
leo__5202 小时前
基于两步成像算法的聚束模式SAR MATLAB实现
开发语言·算法·matlab
前端小白在前进3 小时前
力扣刷题:在排序数组中查找元素的第一个和最后一个位置
数据结构·算法·leetcode
某林2124 小时前
基于SLAM Toolbox的移动机器人激光建图算法原理与工程实现
stm32·嵌入式硬件·算法·slam
修炼地4 小时前
代码随想录算法训练营第四十三天 | 图论理论基础、深搜理论基础、卡码网98. 所有可达路径、797. 所有可能的路径、广搜理论基础
算法·深度优先·图论
iAkuya4 小时前
(leetcode)力扣100 23反转链表(迭代||递归)
算法·leetcode·链表
剪一朵云爱着4 小时前
PAT 1095 Cars on Campus
算法·pat考试
FreeBuf_5 小时前
朝鲜黑客组织“传染性面试“瞄准macOS:新型“DriverFixer“窃密工具浮出水面
macos·面试·职场和发展
牛客企业服务5 小时前
AI面试实用性解析:不是“能不能用”,而是“怎么用好”
人工智能·面试·职场和发展
MicroTech20255 小时前
激光点云快速配准算法创新突破,MLGO微算法科技发布革命性点云配准算法技术
人工智能·科技·算法
Cathy Bryant6 小时前
傅里叶变换(一):简介
笔记·算法·数学建模·信息与通信·傅里叶分析