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

建设020网站需要多少钱什么是成品网站

建设020网站需要多少钱,什么是成品网站,惠山做网站公司,大连在哪个省市一、题目描述 给定 n 个非负整数,用来表示柱状图中各个柱子的高度。每个柱子彼此相邻,且宽度为 1 。 求在该柱状图中,能够勾勒出来的矩形的最大面积。 输入:heights [2,1,5,6,2,3] 输出:10 解释:最大的…

一、题目描述

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

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

输入:heights = [2,1,5,6,2,3]
输出:10
解释:最大的矩形为图中红色区域,面积为 10

二、思路分析:单调栈

首先我们寻找最大的矩阵,我们应该是找到一个像5、6高度的柱子。当你遍历到5的时候,什么也确定不了。因为后面的6比5高,所以肯定还没到最大的矩阵。只有当下一个柱子的高度不再高的时候,我们才能找到最大的矩阵。

当我们遍历到2的时候,我们发现了逆序,也就是可以确定最近的最大矩阵了。首先,我们在遍历的时候,去维护一个单调栈,并且单调栈里存放的位置而不是高度。然后当遇到逆序的时候,我们就可以开始出栈了。比如现在遍历到i=4时,遇到逆序弹出3。然后我们试着计算当前是否为最大矩阵。我们以height[3]=6为高度,width = i - stack[-1] -1 。这里解释一下为什么宽度要这样计算。因为如果位置2和3之间有比6大的数时,我们的栈不会保存这个数的位置,因为遇到了6也就是逆序,所以会弹出比6大的数。 所以回到这个公式,stack[-1]是上一个比6小的位置,这样计算才是真正的宽度。

同样的道理,我们继续弹出单调栈,直到我们栈顶元素比height[i]要小,然后入栈height[i]。

三、代码实现

class Solution:def largestRectangleArea(self, heights: List[int]) -> int:stack = [-1] # 栈底哨兵,方便计算宽度result = 0heights.append(0) # 在末尾加一个 0,作为哨兵,确保栈清空for i,h in enumerate(heights):# 当遇到比栈顶元素小的柱子时,开始出栈,并计算之前能达到的最大面积while stack[-1] != -1 and h <= heights[stack[-1]]:left = stack.pop()# 计算宽度使用stack[-1]作为左端,因为stack中相邻的两个柱子位置 中间可能差好几位# 例如:  stack=[0 1 3 5] 在计算位置3-5的元素肯定是大于heights[5]# 如果小于heights[5] 并且大于heights[3] 则肯定在stack栈中# 如果小于heights[5] 并且小于heights[3] 则位置3不可能在stack中# 所以计算宽度时,要使用stack[-1]来计算w = i - stack[-1] -1height = heights[left]result = max(result,height*w)stack.append(i)return result

http://www.dtcms.com/a/497677.html

相关文章:

  • 国土资源和建设部网站中山免费企业网站建设
  • 白城学做网站优化设计全部答案
  • 在百度上做公司做网站怎么样通过做网站赚钱吗
  • 广东建设网 四川是什么网站体育器材网站建设方案
  • wordpress查看自己网站的ip量如何说明学校网站建设情况
  • 做网站流量要钱吗wordpress 代理服务器
  • 建设信用卡官方网站站长之家查询网站
  • 做网站一个月可以赚多少钱合肥金融直播室网站建设
  • 昆明网站建站网站的seo优化怎么做
  • 东莞做营销网站建设计算机网站建设实验总结
  • 网站建设教程浩森宇特网页设计网站制作流程
  • 北辰网站建设无锡建设网站
  • 福州做网站建设公司建设防伪网站
  • 外贸网站建设公司seo网站推广建站服务商
  • 网站建设经费的函西宁做网站_君博示范
  • 如何在网站建设远程教育本人有大批量手工活寻加工户
  • 免费制作二维码的网站传统企业营销型网站建设
  • 昆山做网站多少钱如何制作微信网站
  • 上海企业网站seo多少钱做问卷给钱的网站
  • 外贸网站制作策划qq个人中心网页版
  • 网络彩票网站开发建站服务器多少钱
  • 做网站需要画原型图么十堰网站制作公司
  • 网站制作应该选什么能打开的a站
  • 网站也会过期吗玉林市住房和城乡建设厅网站
  • 宁波建站模板厂家深圳网络营销公司有哪些
  • 三好街做网站的公司做网站前期费用
  • 做外贸在哪个网站搜狗优化好的网站
  • 网站建设公司工作枯燥吗百度竞价排名机制
  • 帮企业做网站赚钱购物网站支付页面制作
  • 绍兴网站建设制作网站地图生成器哪个好