【Leetcode 42】 接雨水

基础思路:

(1)需要将问题最小化,首先计算第i个位置最多容纳多少雨水(细长的一条水柱),然后求和就是总的雨水量;

(2)第i个位置容纳雨水量 = min(左侧最高, 右侧最高) - height[i]

进一步的:

问题转化成了,如何用最短时间计算所有位置左侧最高点和右侧最高点,这是一个简单的动态规划问题,时间复杂度O(n)

java 复制代码
public static int trap(int[] height) {
        int n = height.length;
        int result = 0;
        int[] lh = new int[n];
        int[] rh = new int[n];

        //计算左侧最高点
        int maxHeight = 0;
        for (int i = 1; i < n; i++) {
            if (height[i-1] > maxHeight) {
                maxHeight = height[i-1];
            }
            lh[i] = maxHeight;
        }

        //计算右侧最高点
        maxHeight = 0;
        for (int i = n-2; i >= 0; i--) {
            if (height[i+1] > maxHeight) {
                maxHeight = height[i+1];
            }
            rh[i] = maxHeight;
        }

        //计算每个位置的水柱,求和
        for (int i = 0; i < n; i++) {
            int wall = lh[i] > rh[i] ? rh[i] :lh[i];
            if (wall <= height[i]) {
                continue;
            }
            result += (wall - height[i]);
        }

        return result;
    }
相关推荐
m0_564914924 分钟前
Altium Designer,AD如何修改原理图右下角图纸标题栏?如何自定义标题栏?自定义原理图模版的使用方法
java·服务器·前端
飞升不如收破烂~4 分钟前
# Spring Boot 跨域请求未到达后端问题排查记录
java·spring boot·后端
AllData公司负责人5 分钟前
【亲测好用】数据集成管理能力演示
java·大数据·数据库·开源
listhi5207 分钟前
压缩感知信号重构的块稀疏贝叶斯学习(BSBL)算法:原理、实现与应用
学习·算法·重构
摸个小yu9 分钟前
【力扣LeetCode热题h100】哈希、双指针、滑动窗口
算法·leetcode·哈希算法
阿蒙Amon10 分钟前
C#每日面试题-值传递和引用传递的区别
java·面试·c#
aloha_78911 分钟前
乐信面试准备
java·spring boot·python·面试·职场和发展·maven
Knight_AL21 分钟前
Spring Boot 多模块项目中优雅实现自动配置(基于 AutoConfiguration.imports)
java·spring boot·mybatis
短剑重铸之日25 分钟前
《RocketMQ研读》面试篇
java·后端·面试·职场和发展·rocketmq
充值修改昵称27 分钟前
数据结构基础:B+树如何优化数据库性能
数据结构·b树·python·算法