面试金典--面试题 17.21. 直方图的水量(不困难的困难题)

文章目录

题目描述

给定一个直方图(也称柱状图),假设有人从上面源源不断地倒水,最后直方图能存多少水量?直方图的宽度为 1。

上面是由数组 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

思路分析

观察图片可知,总面积=黑色面积+蓝色面积。

黑色面积很好求,直接sum(所给数组)就行了。

蓝色面积是答案。所以问题转化成求图中的总面积。

这个其实也很好处理,我们一层一层的去求就好了。

按照所给示例:height=0,1,0,2,1,0,1,3,2,1,2,1
第一层:

left=0,right=11,high=1 (high代表当前层数)。当左右指针指向的区域高度小于high时,左右指针都向中间移动,直到指针指向区域大于等于high的值。若不小于high,则指针不移动。

left不断向右靠近,在第一层left=1时,left和right在输入数组height中的数值都大于当前遍历的层数high。所以第一层的体积就是right-left+1

第二层:

第二层,high = 2,left一直向右移动到left = 3,right向左移动到right = 10。所以第二层体积:right - left + 1 = 8。

第三层同理为1。

所以最后的答案就是,刚求得的总体积-所给数组的和。

完整代码

python 复制代码
class Solution:
    def trap(self, height: List[int]) -> int:
        if not height:
            return 0
        zhuzi = sum(height)
        length = 1 # 表示第几层
        res = 0
        while length<=max(height):
            left = 0
            right = len(height)-1
            while height[left]<length:
                left+=1
            while height[right]<length:
                right-=1
            res += right-left+1
            length+=1
        return res-zhuzi
相关推荐
西安邮电大学15 分钟前
Redis核心数据结构以及应用场景
java·redis·后端·其他·面试
lcj25111 小时前
vector的基本使用 + 手搓成员变量 size capacity begin end operator[] reserve扩容 拷贝构造 赋值析构
开发语言·c++·笔记·面试
神奇小汤圆1 小时前
Miller Rabin:概率之下,证据成群
面试
迈巴赫车主1 小时前
蓝桥杯21247弹跳鞋java
java·开发语言·数据结构·算法·职场和发展·蓝桥杯
贺国亚2 小时前
RAG 检索增强 · 向量库与 Chunking
后端·面试
Raink老师2 小时前
【AI面试临阵磨枪-84】如何看待 RAG vs 微调(Fine-tuning)?选型依据
人工智能·面试·职场和发展
暗不需求2 小时前
React 性能优化秘籍:深入理解 `useMemo` 与 `useCallback`
前端·react.js·面试
better_liang2 小时前
每日Java面试场景题知识点之-数据库与缓存的一致性
java·数据库·redis·面试·分布式系统·缓存一致性·cache aside
JAVA社区2 小时前
Java高级全套教程(九)—— SpringCloud超详细实战详解
java·开发语言·后端·spring cloud·面试·职场和发展
学代码的真由酱2 小时前
【自用】测开面试问题-Java
java·面试·职场和发展