力扣热门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;
    }
}
相关推荐
mmz12072 小时前
深度优先搜索DFS(c++)
c++·算法·深度优先
汀、人工智能3 小时前
[特殊字符] 第103课:单词搜索II
数据结构·算法·均值算法·前缀树·trie·单词搜索ii
wanderist.4 小时前
算法模板-字符串
数据结构·算法·哈希算法
xiaoye-duck4 小时前
《算法题讲解指南:动态规划算法--子序列问题》--29.最长递增子序列的个数,30.最长数对链,31.最长定差子序列
c++·算法·动态规划
Yzzz-F4 小时前
Problem - 2180D - Codeforces
算法
moonsea02034 小时前
2023.9.25
算法
汀、人工智能4 小时前
[特殊字符] Python基础语法速成教程
算法·链表·均值算法·哈希表·lru缓存·python基础语法速成教程
tankeven4 小时前
HJ164 太阳系DISCO
c++·算法
来自远方的老作者4 小时前
第7章 运算符-7.1 算术运算符
开发语言·数据结构·python·算法·算术运算符