LeetCode Hot100 42.接雨水

题目描述

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

42. 接雨水 - 力扣(LeetCode)

思路

用左右两个指针从两头往中间走。在走的过程中,顺便记录下左边遇到的最高值 (lMax) 和右边遇到的最高值 (rMax)。

如果 lMax < rMax,那么对于左边指针 left 来说,它能接多少水只取决于 lMax (因为右边已经有一个比 lMax 更高的 rMax 在兜底了),这个时候就可以确定left所指坐标的积水量。

代码

java 复制代码
class Solution {
    public int trap(int[] height) {
        int ans = 0;
        int lmax = 0, rmax = 0;
        int l = 0, r = height.length - 1;
        while(l < r){
            lmax = Math.max(lmax,height[l]);
            rmax = Math.max(rmax,height[r]);
            if(lmax < rmax){
                ans += lmax-height[l];
                l++;
            }else{
                ans += rmax-height[r];
                r--;
            }
        }
        return ans;
    }
}
相关推荐
沐苏瑶21 小时前
Java 搜索型数据结构全解:二叉搜索树、Map/Set 体系与哈希表
java·数据结构·算法
ZoeJoy81 天前
算法筑基(二):搜索算法——从线性查找到图搜索,精准定位数据
算法·哈希算法·图搜索算法
Alicx.1 天前
dfs由易到难
算法·蓝桥杯·宽度优先
_日拱一卒1 天前
LeetCode:找到字符串中的所有字母异位词
算法·leetcode
云泽8081 天前
深入 AVL 树:原理剖析、旋转算法与性能评估
数据结构·c++·算法
心软小念1 天前
金三银四,全网最详细的软件测试面试题总结
软件测试·面试·职场和发展
Wilber的技术分享1 天前
【LeetCode高频手撕题 2】面试中常见的手撕算法题(小红书)
笔记·算法·leetcode·面试
邪神与厨二病1 天前
Problem L. ZZUPC
c++·数学·算法·前缀和
软件测试媛1 天前
软件测试常见的面试题(46道)
功能测试·面试·职场和发展
梯度下降中1 天前
LoRA原理精讲
人工智能·算法·机器学习