84-Larges-Rectangle-in-Histogram

原题链接

0x0 题目详情

给定 n 个非负整数,用来表示柱状图中各个柱子的高度。每个柱子彼此相邻,且宽度为 1 。 求在该柱状图中,能够勾勒出来的矩形的最大面积。

测试用例: 最大矩形 以上是柱状图的示例,其中每个柱子的宽度为 1,给定的高度为 [2,1,5,6,2,3]。 结果 图中阴影部分为所能勾勒出的最大矩形面积,其面积为 10 个单位。

示例: 输入: [2,1,5,6,2,3] 输出: 10

0x1 解题思路

这道题非常适合使用单调栈来解决,但是又不能完全套用单调栈模板,用到在数组首尾处添加两个哨兵的小技巧。方便最后当数组不为空时做清算工作。

而且这道题使用的单调递增栈,添加的哨兵值为0,值非常合适。因为高度最小为0。所以每道题添加的哨兵值要视情况而定。

具体思路见下图:

最大矩形解题思路

在每次弹出元素时,计算当前高度能够构成的最大矩形面积。

0x2 代码实现

0x3 课后总结

单调栈题目,注意有时候可以通过添加哨兵减少代码复杂度。在递增栈中哨兵比较好使。

Last updated

Was this helpful?