42. 接雨水(Java)

目录

题目描述:

给定 n 个非负整数表示每个宽度为 1 的柱子的高度图,计算按此排列的柱子,下雨之后能接多少雨水。

输入:

bash 复制代码
height = [0,1,0,2,1,0,1,3,2,1,2,1]

输出:

bash 复制代码
6

解释:上面是由数组 0,1,0,2,1,0,1,3,2,1,2,1 表示的高度图,在这种情况下,可以接 6 个单位的雨水(蓝色部分表示雨水)。

代码实现:

java 复制代码
class Solution {
    public int trap(int[] height) {
        int left = 0;// 左指针
        int right = height.length - 1;// 右指针
        int leftHigh = 0;// 左边界高度
        int rightHigh = 0;// 右边界高度
        int sum = 0;// 最终雨水总量
        // 左右指针同时向数组中间遍历
        while (left < right) {// 当左指针等于右指针时,跳出循环
            leftHigh = Math.max(height[left], leftHigh);// 获取左边界最大高度
            rightHigh = Math.max(height[right], rightHigh);// 获取右边界最大高度
            if (height[left] < height[right]) {
                // 当右方高度大于左方高度时,计算左方水坑区域雨水数
                sum += (leftHigh - height[left]);// 累加:左边界减去当前深度
                left++;// 左指针左移
            } else {
                // 其他情况,计算右方水坑区域雨水数
                sum += (rightHigh - height[right]);// 累加:右边界减去当前深度
                right--;// 右指针右移
            }
        }
        return sum;// 返回结果
    }
}
相关推荐
小bo波4 小时前
Java Swing 图形用户界面实验 —— 从算术练习到游戏开发的完整实践
java·课程设计·gui·游戏开发·扫雷·swing
咖啡八杯5 小时前
GoF设计模式——备忘录模式
java·后端·spring·设计模式
SamDeepThinking16 小时前
裁掉那个差程序员后,给你看团队里高手的代码:这个习惯,希望你有
java·后端·程序员
朕瞧着你甚好17 小时前
技术雷达 & Java 集成评估报告 — Apache Tika 3.3.1
java·ai编程
MacroZheng18 小时前
短短几天,暴涨2.8万Star!又一款编程神器开源!
java·人工智能·后端
SamDeepThinking18 小时前
函数式编程:用BiFunction消除多类型分支的代码重复
java·后端·面试
Flittly1 天前
【AgentScope Java新手村系列】(16)从RAG到多路检索
java·spring boot·spring
小兔崽子去哪了1 天前
Java 生成二维码解决方案
java·后端
人活一口气2 天前
从JVM调优到MCP协议:Java全栈技术体系深度总结与企业级架构实践
java·spring boot
NE_STOP2 天前
Vibe Coding -- 完整项目案例实操
java