84-Larges-Rectangle-in-Histogram
Last updated
Was this helpful?
Last updated
Was this helpful?
给定 n 个非负整数,用来表示柱状图中各个柱子的高度。每个柱子彼此相邻,且宽度为 1 。 求在该柱状图中,能够勾勒出来的矩形的最大面积。
测试用例: 以上是柱状图的示例,其中每个柱子的宽度为 1,给定的高度为 [2,1,5,6,2,3]。 图中阴影部分为所能勾勒出的最大矩形面积,其面积为 10 个单位。
示例: 输入: [2,1,5,6,2,3] 输出: 10
这道题非常适合使用单调栈来解决,但是又不能完全套用单调栈模板,用到在数组首尾处添加两个哨兵的小技巧。方便最后当数组不为空时做清算工作。
而且这道题使用的单调递增栈,添加的哨兵值为0,值非常合适。因为高度最小为0。所以每道题添加的哨兵值要视情况而定。
具体思路见下图:
在每次弹出元素时,计算当前高度能够构成的最大矩形面积。
单调栈题目,注意有时候可以通过添加哨兵减少代码复杂度。在递增栈中哨兵比较好使。