记力扣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.规范预处理左右两个端点 ------ 边界条件的正确性保障

相关推荐
暮冬-  Gentle°13 小时前
C++中的工厂模式实战
开发语言·c++·算法
Lisssaa13 小时前
打卡第二十二天
c++·算法·图论
pu_taoc13 小时前
理解 lock_guard, unique_lock 与 shared_lock 的设计哲学与应用场景
开发语言·c++·算法
red_redemption13 小时前
自由学习记录(144)
学习
小刘不想改BUG13 小时前
LeetCode 138.随机链表的复制 Java
java·leetcode·链表·hash table
努力的lpp13 小时前
2024小迪安全课程第四节复习笔记
笔记·安全
XW010599913 小时前
6-函数-1 使用函数求特殊a串数列和
数据结构·python·算法
myloveasuka13 小时前
红黑树、红黑规则、添加节点处理方案
开发语言·算法
沉鱼.4413 小时前
枚举问题集
java·数据结构·算法
2301_8101609513 小时前
C++中的访问者模式高级应用
开发语言·c++·算法