Table of Contents generated with DocToc
单调栈(Monotone Stack):一种特殊的栈。在栈的「先进后出」规则基础上,要求 从 栈顶 到 栈底 的元素是单调递增(或者单调递减)
其中满足从栈顶到栈底的元素是单调递增的栈,叫做「单调递增栈」。满足从栈顶到栈底的元素是单调递减的栈,叫做「单调递减栈」 注意:这里定义的顺序是从「栈顶」到「栈底」。有的文章里是反过来的.
单调栈可以在时间复杂度为 O(n) 的情况下,求解出某个元素左边或者右边第一个比它大或者小的元素。
所以单调栈一般用于解决一下几种问题:
寻找左侧第一个比当前元素大的元素。 寻找左侧第一个比当前元素小的元素。 寻找右侧第一个比当前元素大的元素。 寻找右侧第一个比当前元素小的元素
做法:及时去掉无用数据,保证栈内元素有序
1 每日温度
- 首先记录6
- 遍历3, 发现6比3大,记录下一个更大,栈内 6,3
- 遍历2,发现3比2大,记录下一个更大,栈内 6,3,2
- 遍历5,遍历站内元素,发现6比5大,去除栈内小于5的元素3,2,栈内 6,5
- 遍历5,同理,去除栈内5, 写入新5,栈内 6,5(相同元素保留左边)
方式二从左往右:站内是还没有找到更大的数
2 接雨水
![](.monotone_stack_images/Trapping Rain Water1.png)
- 需要知道栈顶及栈顶下面一个元素
方式一: 找上一个更大元素,在找的过程填坑
前缀最大值:preMax 后缀最大值: suffixMax
1* (min(preMax,suffixMax)-height)