力扣接雨水(解析)

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

示例 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 个单位的雨水(蓝色部分表示雨水)。 

示例 2:

复制代码
输入:height = [4,2,0,3,2,5]
输出:9

找到一个高点,轮训到下一个高点,记录高点的值和下标

相邻的两个高点比较,取最小值

两个高点下标的差值

相邻两个高点的内值总和

两个高点的容量等于最小值乘以距离差

两个高点的接雨水等于 容量减去两个高点内值总和

轮训加上所有雨水值

hight =0, 1, 0, 2, 1, 0, 1, 3, 2, 1, 2, 1 ,3

#记录高点值

hig_dict ={}

for i in range(len(hight)):

if i+1==len(hight):

如果最后一个值大于前一个值

if highti>highti-1

hig_dict i=highti

if higthi>highti+1and higthi>highti-1:

hig_dict i=highti

else:

pass

#高点值下标

keys = listhig_dict.keys

#高点值

values = listhig_dict.values

#所有高点值容量

sum_all =\[\]

for i in range(len(values)):

if i+1==len(values):

break

#取相邻两个高点的最小值

if valuesi<=valuesi+1

tmp = valuesi

else:

tmp = valuesi+1

#-1是因为要去相邻两个数之间有几个值

length = keysi+1 - keysi-1

sum_all.append(tmp*length)

#相邻高点内包含值的总容量

sum_out =\[\]

for k,v in enumerate(hight):

#排除最小高点之前的值

if k < keys0:

continue

#排除最大高点之后的值

if k > keys-1:

break

#排除高点值

if k in keys:

continue

else:

sum_out.append(hightk)

sum_capacity = sum(sum_all) - sum(sum_out)

相关推荐
Brilliantwxx7 分钟前
【C++】 深入理解红黑树:实现与原理全解
数据结构·c++·笔记·算法·青少年编程·红黑树
人道领域13 分钟前
【LeetCode刷题日记】108.将有序数组转换为二叉搜索树
java·算法·leetcode
Dlrb121127 分钟前
数据结构-排序算法
数据结构·算法·排序算法·插入排序·堆排序·希尔排序·快速排序
过期动态28 分钟前
【LeetCode 热题 100】无重复字符的最长子串
java·数据结构·spring boot·算法·leetcode·职场和发展
Raink老师1 小时前
【AI面试临阵磨枪-088】Skill 如何做参数校验、依赖注入、权限控制、超时、重试、幂等?
人工智能·面试·职场和发展
莫等闲-1 小时前
leetcode42. 接雨水 leetcode84.柱状图中最大的矩形
数据结构·c++·算法·leetcode
unicrom_深圳市由你创科技1 小时前
历史数据存储量太大,怎么处理?数据压缩/归档策略?
算法
浅念-1 小时前
LeetCode 记忆化搜索 刷题总结
数据结构·算法·leetcode·职场和发展·深度优先·dfs
菜菜的顾清寒2 小时前
力扣HOT100(44)对称二叉树
数据结构·算法·leetcode
bbaydnog2 小时前
嵌入式面试高频题第4弹:函数指针进阶、堆栈分析、Makefile入门,这3个答不上来就悬了
单片机·面试·职场和发展