当前位置: 首页 > news >正文

门户网站建设实施方案荥阳网站优化公司

门户网站建设实施方案,荥阳网站优化公司,免费做试卷的网站,国家胸痛中心建设网站这是一道 困难 题 题目来自: https://leetcode.cn/problems/trapping-rain-water/ 题目 给定 n 个非负整数表示每个宽度为 1 的柱子的高度图,计算按此排列的柱子,下雨之后能接多少雨水。 示例 1: 输入:height [0,…

这是一道 困难 题

题目来自: https://leetcode.cn/problems/trapping-rain-water/

题目

给定 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 

提示:

  • n==height.lengthn == height.lengthn==height.length
  • 1<=n<=2∗1041 <= n <= 2 * 10^41<=n<=2104
  • 0<=height[i]<=1050 <= height[i] <= 10^50<=height[i]<=105

解题思路

使用单调栈的思路,假如给定的每个柱子是逐个变矮的,那么可以接的雨水就是0

如果这时候突然来了一个变高的柱子 4 ,那么这个柱子就会使得当前柱状图可以接雨水了。

如上图所示:

  1. 先将栈顶的柱子取出(柱子3),使用(其左边柱子的高度和新增柱子高度的最小值 - 其本身高度)* 其宽度,得出当前柱子的接水量,累加到答案中。(注意:如果栈中目前只有一个柱子的话,其左边高度设为0,即不可以接水。)
  2. 这时如果新的栈顶柱子(柱子2)依然比新增的柱子矮,继续取出栈顶柱子并计算其接水量,注意这是宽度应该是柱子3的宽度 + 柱子2的宽度。
  3. 这时栈顶柱子1的高度 大于 新增的柱子4 的高度,柱子4入栈,注意:这时柱子4的宽度 = 柱子2 + 柱子3 + 柱子4 的总宽度,即前面所有出栈的柱子的宽度都需要保留下来,因为如果再来一个第5个柱子的高度 > 柱子4的高度的话,前面那么宽度还是有用的。

代码实现

Java 代码实现

class Solution {private Deque<int[]> stack = new LinkedList<>();public int trap(int[] height) {int n = height.length ;if(n <= 1){return 0;}int ans = 0;for(int h : height){int w = 0;while(!stack.isEmpty() && h > stack.peek()[1]){int[] top = stack.pop();w += top[0];if(!stack.isEmpty()){ans += w * (Math.min(stack.peek()[1], h) - top[1]);}}stack.push(new int[]{w + 1, h});}return ans;}
}

Go 代码实现

func trap(height []int) int {n := len(height)if n <= 1 {return 0}stack := [][]int{}ans := 0for _, h := range height {if len(stack) == 0 {stack = append(stack, []int{1, h})continue}w := 0for len(stack) > 0 && h > stack[len(stack) - 1][1] {top := stack[len(stack) - 1]stack = stack[:len(stack) - 1]w += top[0]if len(stack) > 0 {ans += w * (min(stack[len(stack) - 1][1], h) - top[1])}}stack = append(stack, []int{w + 1, h})}return ans
}func min(a int, b int) int {if a > b {return b}return a
}

复杂度分析

时间复杂度:O(n)O(n)O(n)

空间复杂度:O(n)O(n)O(n)

http://www.hkea.cn/news/15333/

相关文章:

  • 高安市帮助做公司网站武汉seo外包平台
  • 做阿里网站需要的faq惠州网站seo排名优化
  • 不花钱可以做网站吗长春seo网站管理
  • 专业制作网站电脑关键词排名靠前
  • 自适应网站制作教程预测2025年网络营销的发展
  • 建设网站需要什么资质竞价排名什么意思
  • 高端网站建设公司增长广西壮族自治区
  • 搜不到自己的网站搜索引擎seo优化平台
  • 网站制作比较好的公司百度注册入口
  • 湛江住房和城乡建设部网站站内营销推广方案
  • 网站打开速度加快怎么做营业推广
  • 网站开发系统调研目的客服系统网页源码2022免费
  • 免费下载素材的设计网站广东网络优化推广
  • 谁做视频网站百度网站排名规则
  • 做彩票的网站怎么创建网站快捷方式
  • 郑州做网站的公司软文文案范文
  • 网站制作工作室制作平台微信社群营销
  • 网站设计专业有哪些课程seo推广怎么样
  • 免费企业网站程序asp济南网络优化网站
  • 保山企业网站建设百度搜索链接入口
  • 哈尔滨百姓网免费发布信息镇江搜索优化技巧
  • 好的免费个人网站专业网站制作网站公司
  • 做网站需要独立ip吗网站文章优化技巧
  • 建设网站需要哪些元素网站seo优化8888
  • 外贸网站建设经验佛山营销型网站建设公司
  • 微商城网站建设推广qq群推广方法
  • 郑州做的比较好网站公司吗杭州seo 云优化科技
  • 高校网站建设方案新站如何让百度快速收录
  • 免费网站建设案例莆田seo推广公司
  • 做网页设计卖钱的网站优化网站平台