力扣热门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;
    }
}
相关推荐
灵感__idea13 分钟前
Hello 算法:“走一步看一步”的智慧
前端·javascript·算法
lwf0061642 小时前
导数学习日记
学习·算法·机器学习
头发够用的程序员3 小时前
从滑动窗口到矩阵运算:img2col算法基本原理
人工智能·算法·yolo·性能优化·矩阵·边缘计算·jetson
武帝为此3 小时前
【数据清洗缺失值处理】
python·算法·数学建模
Halo_tjn4 小时前
Java 基于字符串相关知识点
java·开发语言·算法
念越4 小时前
算法每日一题 Day08|双指针法解决三数之和
算法·力扣
黎阳之光4 小时前
黎阳之光透明管理:视频孪生重构智慧仓储新范式
人工智能·算法·安全·重构·数字孪生
6Hzlia5 小时前
【Hot 100 刷题计划】 LeetCode 199. 二叉树的右视图 | C++ DFS 逆序遍历
c++·leetcode·深度优先
CappuccinoRose5 小时前
回溯法 - 软考备战(四十三)
算法·排列组合·路径·n皇后·子集·解数独·岛屿
AC赳赳老秦5 小时前
OpenClaw进阶技巧:批量修改文件内容、替换关键词,解放双手
java·linux·人工智能·python·算法·测试用例·openclaw