155. 最小栈
难度简单745
设计一个支持 push
,pop
,top
操作,并能在常数时间内检索到最小元素的栈。
push(x)
—— 将元素 x 推入栈中。pop()
—— 删除栈顶的元素。top()
—— 获取栈顶元素。getMin()
—— 检索栈中的最小元素。
示例:
输入:
["MinStack","push","push","push","getMin","pop","top","getMin"]
[[],[-2],[0],[-3],[],[],[],[]]
输出:
[null,null,null,null,-3,null,0,-2]
解释:
MinStack minStack = new MinStack();
minStack.push(-2);
minStack.push(0);
minStack.push(-3);
minStack.getMin(); --> 返回 -3.
minStack.pop();
minStack.top(); --> 返回 0.
minStack.getMin(); --> 返回 -2.
- push()方法: 每当push() 新值进来时,如果小于等于minstack栈顶值,则一起Push() 到minstack.即更新了栈顶最小值
- pop方法: 判断pop() 出去的元素值是否是minstack栈顶元素(即最小值),如果是则将minstack栈顶元素一起pop(),这样可以保证
min_stack
栈顶元素始终是stack
中的最小值。 - getMin()方法: 返回min_stack栈顶即可。
min_stack
作用分析:
- min_stack等价于遍历stack所有元素,把升序的数字都删除掉,留下一个从栈底到栈定降序的栈
- 相当于给stack中的降序元素做了标记,每当pop() 这些元素,min_stack会将相应的栈顶元素pop() 出去,保证其栈顶元素始终是stack的最小元素
代码:
package com.nie.LEE.jike.CLass04StackQuenu;
import java.util.Stack;
public class LEE155 {
class MinStack {
private Stack<Integer> stack;
private Stack<Integer> minStack;
/**
* initialize your data structure here.
*/
public MinStack() {
// # 数据栈
stack = new Stack<>();
// # 辅助栈
minStack = new Stack<>();
}
public void push(int x) {
stack.push(x);
if (minStack.isEmpty() || x <= minStack.peek()) {
minStack.push(x);
} else {
return;
}
}
public void pop() {
if (stack.pop().equals(minStack.peek())) {
minStack.pop();
}
}
public int top() {
return stack.peek();
}
public int getMin() {
return minStack.peek();
}
}
}