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

相关推荐
漫随流水几秒前
leetcode算法(559.N叉树的最大深度)
数据结构·算法·leetcode·二叉树
池塘的蜗牛1 分钟前
NR PDSCH和CSI 正交导频设计
算法
FAFU_kyp6 分钟前
Rust 所有权(Ownership)学习
开发语言·学习·rust
2501_9423264410 分钟前
科学开发大脑潜能,提升学习效率
学习
deng-c-f21 分钟前
Linux C/C++ 学习日记(60):redis(一):基本介绍
学习
仙女修炼史28 分钟前
How transferable are features in deep neural networks
人工智能·深度学习·学习
CoovallyAIHub36 分钟前
仅192万参数的目标检测模型,Micro-YOLO如何做到目标检测精度与效率兼得
深度学习·算法·计算机视觉
hhcccchh41 分钟前
学习vue第十二天 Vue开发工具链指南:从手工作坊到现代化工厂
前端·vue.js·学习