【力扣面试】面试题 03.02. 栈的最小值
文章目录- 题目
- 解题思路
- 代码
请设计一个栈,除了常规栈支持的pop与push函数以外,还支持min函数,该函数返回栈元素中的最小值。执行push、pop和min操作的时间复杂度必须为O(1)。
示例:
解题思路MinStack minStack = new MinStack();
minStack.push(-2);
minStack.push(0);
minStack.push(-3);
minStack.getMin(); --> 返回 -3.
minStack.pop();
minStack.top(); --> 返回 0.
minStack.getMin(); --> 返回 -2.
思路:
根据题意,我们需要在常量级的时间内找到最小值!
这说明,我们绝不能在需要最小值的时候,再做排序,查找等操作来获取!
1、用两个栈来存储
2、一个栈stack存储常规数据,一个栈minstack存储当前的最小值,初始化的时候,minstack要存储一个Integer.MAX_VALUE最大值。
代码
class MinStack {
Stack stack;
Stack minStack;
public MinStack() {
stack = new Stack<>();
minStack = new Stack<>();
minStack.push(Integer.MAX_VALUE);
}
public void push(int x) {
stack.push(x);
minStack.push(Math.min(minStack.peek(),x));
}
public void pop() {
stack.pop();
minStack.pop();
}
public int top() {
return stack.peek();
}
public int getMin() {
return minStack.peek();
}
}
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/min-stack-lcci



