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;
    }
}
相关推荐
kishu_iOS&AI6 分钟前
Pytorch —— 自动微分模块
人工智能·pytorch·python·深度学习·算法·线性回归
北风toto19 分钟前
深入解析JWT Token生成原理与安全加密技术详解
算法·安全·哈希算法
DeepModel23 分钟前
通俗易懂讲透 EM 算法(期望最大化)
人工智能·python·算法·机器学习
Pentane.26 分钟前
【力扣hot100】【Leetcode 15】三数之和|暴力枚举 双指针 算法笔记及打卡(14/100)
数据结构·笔记·算法·leetcode
不知名的老吴32 分钟前
高阶函数的应用与函数对象概念
算法
Mr_pyx37 分钟前
【LeetCode Hot 100】 - 缺失的第一个正数完全题解
数据结构·算法
wydxry44 分钟前
深入解析自适应光学中的哈特曼波前传感技术:原理、算法与智能化前沿
大数据·人工智能·算法
xieliyu.1 小时前
Java顺序表实现扑克牌Fisher-Yates 洗牌算法
java·数据结构·算法·javase
计算机魔术师1 小时前
【AI面试八股文 | 面试题库】AI工程师面试题库:100+来源的系统性解题思路
人工智能·面试·职场和发展·ai工程师面试·system design
ICscholar1 小时前
推荐系统常用指标NDCG含义及公式
人工智能·深度学习·算法