题目信息
-
题目:剑指 Offer 30. 包含min函数的栈
-
时间: 2020-09-08
-
题目链接:Leetcode
-
tag:栈
-
难易程度:简单
-
题目描述:
定义栈的数据结构,请在该类型中实现一个能够得到栈的最小元素的 min 函数在该栈中,调用 min、push 及 pop 的时间复杂度都是 O(1)。
示例:
1 | MinStack minStack = new MinStack(); |
解题思路
本题难点
普通栈的 push() 和 pop() 函数的复杂度为 O(1);而获取栈最小值 min() 函数需要遍历整个栈,复杂度为 O(N)。
具体思路
将 min() 函数复杂度降为 O(1) ,可通过建立辅助栈实现;
-
数据栈dataStack : 栈 dataStack用于存储所有元素,保证入栈 push() 函数、出栈 pop() 函数、获取栈顶 top() 函数的正常逻辑。
-
辅助栈 minStack: 栈 minStack 中存储栈 dataStack 中所有 非严格降序 的元素,则栈 dataStack 中的最小元素始终对应栈 minStack 的栈顶元素,即 min() 函数只需返回栈minStack 的栈顶元素即可。
-
因此,只需设法维护好栈 minStack 的元素,使其保持非严格降序,即可实现
min()
函数的 O(1)复杂度。
代码
1 | class MinStack { |
复杂度分析:
- 时间复杂度 O(1) : push(), pop(), top(), min() 四个函数的时间复杂度均为常数级别。
- 空间复杂度 O(N) : 当共有 N 个待入栈元素时,辅助栈 minStack 最差情况下存储 N 个元素,使用 O(N) 额外空间。
其他优秀解答
解题思路
如果当前压入的值比当前最小值,则压入一个当前最小值,再压入当前的值!
代码
1 | class MinStack { |