单调栈monotonous stack
一个比较好理解的数据结构,正如其名,具有单调性的栈。
vector<int> mono_s;//stack is also available
for(int i=0;i<nums.size();i++)
{
while(!mono_s.empty()&&nums[mono_s.back()]<nums[i])
{
/*the operations you want to do
*
*/
mono_s.pop_back();
}
mono_s.push_back(i);
}
网上搜索得到的资料还是蛮多,其代码也不难理解。满足单调性就入栈,不满足就把不满足单调性的全部弹出栈。那么为什么作者还要重复讲这个东西呢?因为网上资料大多通过例题讲述,然而笔者愚笨,看完一题只能会这一题,触类旁通似乎有些困难,而且随着时间推移便渐渐忘却。因此做一归纳总结。
个人认为,对于单调栈来说,比较难的一点在于:
到底什么时候该用单调栈。或者说,什么时候该想到用单调栈。
总结归纳一下单调栈的常用情况:
1.在数组中寻找下一个更大元素/更小元素
2.从数组中去掉K个元素(其本质也是为了寻找更大和更小元素)