leetcode-155. 最小栈

155. 最小栈

  • 首先关键是动态维护最小值,就是弹出元素为最小值的时候,如何知道次最小值

  • 可以使用一个辅助栈mStack,mStack只用于存储push路径上的所有曾经的最小值mStack的栈顶一直都是stack中的最小值

  • 当第一次push val,或者后续每次push的时候小于mStack,就向mStack里添加

  • 比较Integer需要用equal(),小心小于-128-127这个范围里的数字

 


class MinStack {

    /*
        关键是维护最小值,并且弹出栈顶元素最小值的时候,怎么知道次最小值。
     */
    private Stack<Integer> stack; //原栈
    private Stack<Integer> mStack; //最小栈,保存着那些曾经最小的值

    public MinStack() {
        this.stack = new Stack<>();
        this.mStack = new Stack<>();
    }
    
    public void push(int val) {
        stack.push(val);
        if(mStack.isEmpty() || val <= mStack.peek()){//第一次添加val,把最小值存贮到mStack的栈顶,每次push数的时候小于mStack的栈顶则同时push到mStack
            mStack.push(val);
        }
    }
    
    public void pop() {
        if(stack.pop().equals(mStack.peek())){
            mStack.pop();
        }
    }
    
    public int top() {
        return stack.peek(); //返回原栈顶元素
    }
    
    public int getMin() {
        return mStack.peek(); //返回最小栈顶
    }
}

 

posted on 2022-10-12 22:41  老菜农  阅读(15)  评论(0编辑  收藏  举报

导航