单调栈
这是笔者的第一篇博客,由于笔者自身水平的限制。用词可能不够准确,句子不太通顺,代码水平可能也不太行,敬请指出,感激不尽!
我们都知道栈(Stack)是一种先入后出的数据结构,而单调栈建立在栈的基础上,它区别于普通的栈的特殊之处在于
栈中的元素一直保持着单调递增/单调递减的关系
比如单调递增栈中的元素自栈底至栈顶元素(0~n-1)间都是单调递增的,单调递减栈中的元素都是单调递减的。
为了加深印象,我们可以先以单调递减栈为例,看一个例子~
有一组数nums[6] = {10,1,8,12,6,4}按照如下规则进行操作:
- 如果栈为空/正在处理的数小于栈顶的数,则进栈;
- 如果正在处理的数大于栈顶的数,则将栈顶元素出栈,然后继续进行判断。
OK,首先我们将栈置空,然后再来一个一个地读数。
-
首先读到了10,此时栈为空,10进栈,现在栈的状态: {10}
-
读到了1,栈顶元素为10,1<10,1进栈,栈的状态: {10 , 1}
-
读到8,栈顶元素为1,8>1,那么我们将1出栈;
继续判断,8<10,所以8进栈,栈的状态: {10,8}
-
读到数12,栈顶元素为8,12>8,将8出栈;
继续判断,12>10,所以10出栈,此时栈已为空,将12进栈: {12}
-
读到6,6<12,进栈;{12,6}
-
读到4,4<6,将4进栈。 {12,6,4}
读到这边,