力扣热门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;
    }
}
相关推荐
oddsand115 分钟前
pgvector 三大相似度算法
人工智能·算法·机器学习
运筹vivo@23 分钟前
LeetCode 2574. 左右元素和的差值
算法·leetcode·职场和发展·每日一题
计算机安禾38 分钟前
【数据库系统原理】第4篇:关系数据结构的形式化定义:域、笛卡尔积与关系模式
数据结构·数据库·算法
手写码匠1 小时前
手写 DeepSeek 推理引擎优化:从 FP16 到 INT4 的量化加速实战
人工智能·深度学习·算法·aigc
GuWenyue1 小时前
LeetCode 76 最小覆盖子串|JS 滑动窗口标准解法
前端·算法·面试
一只齐刘海的猫1 小时前
【Leetcode】移动零
算法·leetcode·职场和发展
人道领域1 小时前
【LeetCode刷题日记】131.分割回文串,动态规划优化
java·开发语言·leetcode
落羽的落羽2 小时前
【项目】JsonRpc框架——开发实现1(细节功能、字段定义、抽象层、具象层)
linux·服务器·网络·c++·人工智能·算法·机器学习
handler012 小时前
【算法】并查集(普通/扩展/带权)模板与例题
数据结构·c++·笔记·算法·c·图论·查并集
qq7422349843 小时前
从“感知”到“决断”:测评百度伐谋产业决策智能体的端到端推理与行动机制
人工智能·算法·百度·大模型·运筹优化