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

的网站建设软文广告

的网站建设,软文广告,网站首页html代码,网站开发时间表84. 柱状图中最大的矩形 正文 题目如下 给定 n 个非负整数,用来表示柱状图中各个柱子的高度。每个柱子彼此相邻,且宽度为 1 。 求在该柱状图中,能够勾勒出来的矩形的最大面积。 这道题暴力很简单,但是时间复杂度是O(N^2)&#xf…

84. 柱状图中最大的矩形


正文

题目如下

给定 n 个非负整数,用来表示柱状图中各个柱子的高度。每个柱子彼此相邻,且宽度为 1 。

求在该柱状图中,能够勾勒出来的矩形的最大面积。

这道题暴力很简单,但是时间复杂度是O(N^2),在这里我们不予考虑,我在这里主要介绍一下单调栈的做法。

单调栈主要的思路就是,将遍历到的元素下标压入栈中,如果当前遍历的元素小于栈顶元素,就没有遵循单调的原则,需要先把栈中大于当前遍历到的数字的元素弹出,再把当前遍历的元素压入栈中,在这个过程中,我们还需要重新计算最大的矩形面积。

如何计算?

  • 首先我们需要明确,我们的栈是存储的下标,通过下标的差值我们可以计算出宽度,而且栈中元素是保持着单调递增的趋势,所以我们每次弹出的下标对应的数值都可以作为我们的矩形的高,这样便可以计算出我们的矩形面积。

为什么这样做能得出正确答案?

  • 首先,我们需要先了解一下暴力的做法,暴力是通过两个for循环遍历来实现的矩形的面积最大值计算,而单调栈是只在每次弹出元素的时候重新计算矩形面积,每个元素最多入栈,出栈一次,所以时间复杂度远小于暴力做法。
  • 但我们仔细想一下就能够知道,暴力做法是有很多多余的计算步骤的,比如以[1,2,3,4,5,6,1]为例子,遍历1的时候,会把2,3,4,5,6,1遍历完,显然效率很低,而单调栈在弹出元素时,能够确定,以当前下标对应的矩形的高的最大面积是多少,想清楚这一点,这道题就迎刃而解了。

下面是代码

func largestRectangleArea(heights []int) int {var st []intans := 0heights = append(heights, -1)for i := 0; i < len(heights); i ++ {for len(st) != 0 && heights[i] < heights[st[len(st) - 1]] {idx := st[len(st) - 1]st = st[:len(st) - 1]var l intif len(st) == 0 {l = -1} else {l = st[len(st) - 1]}ans = Max(ans, (i - l - 1) * heights[idx])}st = append(st, i)}return ans}func Max(a int, b int) int {if a >= b {return a}return b}

结语

这道题思路来源于bilibili,如果觉得不清晰可以看看这个视频。

http://www.khdw.cn/news/11841.html

相关文章:

  • 用dw做网站的代码百度搜索广告价格
  • 网站建设怎么样工作室北京搜索引擎优化管理专员
  • 有没有好的网站可以学做头发旅行网站排名前十名
  • 深圳设计周展会2023时间seo网站关键词排名优化公司
  • 如何将自己做的网站推广出去互联网广告投放公司
  • 百度小程序登录入口seo前线
  • 微信开发网站建设人力资源管理师
  • 保险网站最近一周新闻大事
  • 泰州企业网站建设公司上海优化价格
  • 怎样做自己的小说网站网站seo推广员招聘
  • 网站建设图片网络营销是做什么的
  • 做视频导航网站有哪些品牌营销策划公司哪家好
  • 番禺网站建设培训论述搜索引擎优化的具体措施
  • webapp开发教程广州网站优化公司排名
  • 宜兴建设局 审图中心 网站开网站需要多少钱
  • 商城网站需求西安网站seo哪家公司好
  • 艾奇视觉网站建设今日热点新闻头条
  • 重庆便宜网站建设百度seo正规优化
  • 枣庄建设工程管理局网站兰州seo快速优化报价
  • 网站建设 网站制作app运营方案
  • 长沙做网站的公司有哪些网络代理app
  • 做响应式网站代码免费的网页入口
  • 纪委网站举报怎么做网站数据统计工具
  • wordpress下载网站模板怎么用sem分析是什么意思
  • 网站开发 软文靠谱的免费建站
  • 佛山网站建设专业公司湘潭网站seo
  • 网站建设公司 提成宁波正规站内优化seo
  • wordpress admin-ajax.php 漏洞郑州众志seo
  • 移动端网站的优点网络热词2022
  • 空间租用网站模板互联网营销推广