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;// 返回结果
    }
}
相关推荐
慕木沐4 分钟前
Google ADK Java 1.0版本 核心机制与实战 Demo
java·开发语言·python
Roann_seo%9 分钟前
C++文件操作完全指南:从文本读写到二进制文件处理
开发语言·c++
焦虑的说说1 小时前
秒杀系统设计方案
java
huangdong_1 小时前
淘宝商品SKU图自动分类技术深度解析:从DOM解析到智能归档
开发语言·javascript·ecmascript
阿正的梦工坊1 小时前
【Rust】12-借用检查器与非词法生命周期
开发语言·后端·rust
许彰午1 小时前
30_Java Stream流操作全解
java·windows·python
qq_2518364571 小时前
基于java Web网络订餐系统设计与实现 源码文档
java·开发语言·前端
秋92 小时前
3年经验Python后端转AI Engineer:3个月实战转型计划(2026版)
开发语言·人工智能·python
凡人叶枫2 小时前
Effective C++ 条款17:以独立语句将 newed 对象置入智能指针
java·linux·开发语言·c++·算法
飞天狗1112 小时前
零基础JavaWeb入门——第2课:让网页“活”起来 —— JSP是什么?
java·开发语言·前端·后端·web