力扣热门100题之接雨水

一句话总结

双指针 从两端往中间走,利用短板效应 (哪边矮,哪边就能存水),一遍遍历算出总共能接多少雨水。

边界条件(非常重要):

java 复制代码
if (height == null || height.length <= 2) {
    return 0;
}
  • 如果数组为空,或者柱子 ≤ 2 根
  • 根本存不住水,直接返回 0
  • 比如:[2,3] 中间没有凹槽,存不了水

接雨水靠的是 "短板"!比如:左边最高 2,右边最高 3 → 只能按 2 来存水。所以:哪边柱子更矮,哪边就是短板,就计算哪边的存水量!

完整代码实现:

java 复制代码
class Solution {
    public int trap(int[] height) {
        //柱子长度小于2无法接雨水
        if(height == null || height.length <= 2){
            return 0;
        }

        int left = 0;  //左指针
        int right = height.length - 1; //右指针
        int maxLeft = 0;  //左边最高柱子
        int maxRight = 0; //右边最高柱子
        int totalWater = 0; //总接水量

        while(left < right){
            if(height[left] < height[right]){
                if(height[left] >= maxLeft){
                    maxLeft = height[left];
                }else{
                    totalWater += maxLeft - height[left];
                }
                left++;
            }else{
                if(height[right] >= maxRight){
                    maxRight = height[right];
                }else{
                    totalWater += maxRight - height[right];
                }
                right--;
            }
        }

        return totalWater;
    }
}
相关推荐
To_OC15 小时前
LC 994 腐烂的橘子:人人都说是 BFS 入门题,我却写了三遍才过
javascript·算法·leetcode
金銀銅鐵19 小时前
[Python] 扩展欧几里得算法
python·数学·算法
To_OC21 小时前
LC 200 岛屿数量:经典 DFS 入门题,我第一次写居然连方向都搞错了
javascript·算法·leetcode
To_OC2 天前
LC 128 最长连续序列:别上来就排序,O (n) 解法才是这题的灵魂
javascript·算法·leetcode
05Kevin2 天前
lk每日冒险题--数据结构6.27
算法
To_OC3 天前
从一次栈溢出报错说起,我把递归彻底扒明白了
javascript·算法·程序员
千纸鹤安安3 天前
千问Qwen-AgentWorld来了:一个语言模型搞定七大Agent场景,GPT-5.4都输了
算法
七牛开发者3 天前
MCP 到底是什么?为什么 Agent 都想接上它
算法·aigc·agent