直方图的水量 力扣面试题 17.21.

阅读: 评论:0

直方图的水量 力扣面试题 17.21.

直方图的水量 力扣面试题 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

思路:


左右视图,同一位置取较小值, 便是当前位置能够储水的最大高度, 最后在减去构成容器的直方图的高度,就是最终储水的结果

int trap(vector<int>& height) {// 从左向右得到直方图的左视图, 在得到右视图, 每个位置取较小值int res = 0;pty())return res;vector<int> left(height.size(), 0);vector<int> right(height.size(), 0);int lmax, rmax = 0;for(int i = 0; i < height.size(); ++i){// 从左向右, 得到直方图的左视图left[i] = max(lmax, height[i]);if(lmax < height[i])lmax = height[i];// 从右向左,得到直方图的右视图right[height.size()-1-i] = max(rmax, height[height.size()-1-i]);if(rmax < height[height.size()-1-i])rmax = height[height.size()-1-i];}for(int i = 0; i < height.size()-1; ++i){// 取左,右视图同一位置处, 较小值就是就可以储水的最高高度, 再减去构成直方图的值res += (min(left[i], right[i]) - height[i]);}return res;}

本文发布于:2024-01-30 17:25:46,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/170660675221642.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:直方图   水量   面试题
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23