1. class MinStack {
    2. //辅助栈的使用
    3. //1:当一个元素要入栈时,我们取当前辅助栈的栈顶存储的最小值,与当前元素比较得出最小值,将这个最小值插入辅助栈中;
    4. //2:当一个元素要出栈时,我们把辅助栈的栈顶元素也一并弹出
    5. //3:在任意一个时刻,栈内元素的最小值就存储在辅助栈的栈顶元素中
    6. Stack<Integer> stack;
    7. Stack<Integer> minStack;
    8. public MinStack() {
    9. stack = new Stack<Integer>();
    10. minStack = new Stack<Integer>();
    11. minStack.push(Integer.MAX_VALUE);
    12. }
    13. public void push(int val) {
    14. stack.push(val);
    15. minStack.push(Math.min(minStack.peek(),val));
    16. }
    17. public void pop() {
    18. stack.pop();
    19. minStack.pop();
    20. }
    21. public int top() {
    22. return stack.peek();
    23. }
    24. public int getMin() {
    25. return minStack.peek();
    26. }
    27. }
    28. /**
    29. * Your MinStack object will be instantiated and called as such:
    30. * MinStack obj = new MinStack();
    31. * obj.push(val);
    32. * obj.pop();
    33. * int param_3 = obj.top();
    34. * int param_4 = obj.getMin();
    35. */