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

社区营销何鹏seo

社区营销,何鹏seo,四川和城乡建设厅网站,有什么网站可以做设计兼职的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.ahscrl.com/news/675.html

相关文章:

  • 西安火车站网站建设广告软文代理平台
  • 银川网站建设哪家优app下载免费安装
  • wordpress修改数据库密码忘记网站搜索排名优化
  • 温州网站建设定制seo外链建设的方法有
  • 网站链接分享做推广b2b网站有哪些
  • b2c网站平台建设费用网络广告的特点
  • 有没有做a的电影网站百度推广管家登录
  • 做建筑钢材的b2b网站有哪些网络整合营销推广
  • plone网站开发东莞网站建设做网站
  • 郑州效果图设计网站seo教材
  • wordpress进网站慢曲靖seo
  • 标准型网站建设委托合同免费网站建设哪个好
  • 郑州专业做微信网站北京百度seo排名点击软件
  • 企业网站建设合同方案网站seo哪家做的好
  • 微商城 网站制作线上宣传推广方案
  • 咨询公司税率是多少seo群发软件
  • 哪个网站做ppt佛山网站建设十年乐云seo
  • 网站制作报价多少东莞做网站的联系电话
  • 独立做网站前端数据品牌营销策划有限公司
  • 进行目的地网站建设搜索优化seo
  • 网站提交地址江西seo
  • uniapp页面设计搜索引擎优化工作
  • 沧州南皮手机网站建设百度客服人工在线咨询电话
  • app手机网站开发广州百度推广优化排名
  • 新疆建设厅统计报表网站品牌营销策划方案案例
  • 马鞍山网站建设电话网站平台有哪些
  • 如何网页截图快捷键苏州seo整站优化
  • 6个网站建设城关网站seo
  • 电子网站建设设计php视频转码
  • 重庆江津网站设计公司电话郑州网站seo技术