记力扣42.接雨水 练习理解

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

例:

复制代码
输入:height = [0,1,0,2,1,0,1,3,2,1,2,1]
输出:6
解释:上面是由数组 [0,1,0,2,1,0,1,3,2,1,2,1] 表示的高度图,在这种情况下,可以接 6 个单位的雨水(蓝色部分表示雨水)。 

思路:

这个问题我最开始想到的是通过相邻的列数进行比较看他是不是最小的那个进行统计他的接水量,依次遍历,按照这个思路:先用一个空列表left_max去遍历出从左往右相邻最大列数的数字,再用一个从右往左去遍历相邻最大的列数,然后每一列的接水量就是左右相邻的最小值减去该位置的列数。(动态规划)

python 复制代码
from typing import List
class Solution:
    def trap(self,height:List[int])->int:
        n=len(height)
        left_max=[0]*n
        right_max=[0]*n
        left_max[0]=height[0]
        for i in range(1,n):
            left_max[i]=max(left_max[i-1],height[i])
        right_max[-1]=height[-1]
        for j in range(n-2,-1,-1):
            right_max[j]=max(right_max[j+1],height[j])
        ans=0
        for i in range(n):
            ans+=min(left_max[i],right_max[i])-height[i]
        return ans

难点:

1.理解接水量的计算逻辑 ------ 当前位置接水量 = min (左侧最大高度,右侧最大高度) - 当前高度

2.高效统计左右两侧的最大高度 ------ 单向遍历 + max 复用子问题结果

3.规范预处理左右两个端点 ------ 边界条件的正确性保障

相关推荐
进击的荆棘14 小时前
优选算法——滑动窗口
c++·算法·leetcode
csdn_aspnet14 小时前
奈飞工厂算法:个性化推荐系统的极限复刻
算法·netflix·奈飞
小白_ysf14 小时前
Vue 中常见的加密方法(对称、非对称、杂凑算法)
前端·vue.js·算法
多米Domi01115 小时前
0x3f 第49天 面向实习的八股背诵第六天 过了一遍JVM的知识点,看了相关视频讲解JVM内存,垃圾清理,买了plus,稍微看了点确定一下方向
jvm·数据结构·python·算法·leetcode
微露清风1 天前
系统性学习Linux-第二讲-基础开发工具
linux·运维·学习
不会代码的小猴1 天前
Linux环境编程第六天笔记--system-V IPC
linux·笔记
阳光九叶草LXGZXJ1 天前
达梦数据库-学习-48-DmDrs控制台命令(同步之Manager、CPT模块)
linux·运维·数据库·sql·学习
乌恩大侠1 天前
【笔记】USRP 5G 和 6G 参考架构
笔记·5g
biuyyyxxx1 天前
Python自动化办公学习笔记(一) 工具安装&教程
笔记·python·学习·自动化
舟舟亢亢1 天前
Java集合笔记总结
java·笔记