lc-155


/**
Design a stack that supports push, pop, top, and retrieving the minimum element 
in constant time. 

 Implement the MinStack class: 

 
 MinStack() initializes the stack object. 
 void push(int val) pushes the element val onto the stack. 
 void pop() removes the element on the top of the stack. 
 int top() gets the top element of the stack. 
 int getMin() retrieves the minimum element in the stack. 
 

 You must implement a solution with O(1) time complexity for each function. 

 
 Example 1: 

 
Input
["MinStack","push","push","push","getMin","pop","top","getMin"]
[[],[-2],[0],[-3],[],[],[],[]]

Output
[null,null,null,null,-3,null,0,-2]

Explanation
MinStack minStack = new MinStack();
minStack.push(-2);
minStack.push(0);
minStack.push(-3);
minStack.getMin(); // return -3
minStack.pop();
minStack.top();    // return 0
minStack.getMin(); // return -2
 

 
 Constraints: 

 
 -2³¹ <= val <= 2³¹ - 1 
 Methods pop, top and getMin operations will always be called on non-empty 
stacks. 
 At most 3 * 10⁴ calls will be made to push, pop, top, and getMin. 
 
 Related Topics栈 | 设计 

 👍 1400, 👎 0 

*/	
//leetcode submit region begin(Prohibit modification and deletion)
class MinStack {

    List<Integer> stackList;

    int minIndex;



    public MinStack() {
        stackList = new ArrayList<>();
        minIndex = -1;
    }

    public void push(int val) {
        if (minIndex == -1) {
            minIndex = 0;
        } else if (val < stackList.get(minIndex)) {
            minIndex = stackList.size();
        }

        stackList.add(val);
    }

    public void pop() {
        stackList.remove(stackList.size() - 1);

        if (minIndex == stackList.size()) {
            int minIndex = -1;
            int minV = Integer.MAX_VALUE;

            for (int i = 0; i < stackList.size(); i++) {
                if (stackList.get(i) < minV) {
                    minV = stackList.get(i);
                    minIndex = i;
                }
            }

            this.minIndex = minIndex;
        }
    }

    public int top() {
        return stackList.get(stackList.size() - 1);
    }

    public int getMin() {
        if (minIndex == -1) {
            return Integer.MAX_VALUE;
        }
        return stackList.get(minIndex);
    }
}

/**
 * Your MinStack object will be instantiated and called as such:
 * MinStack obj = new MinStack();
 * obj.push(val);
 * obj.pop();
 * int param_3 = obj.top();
 * int param_4 = obj.getMin();
 */
//leetcode submit region end(Prohibit modification and deletion)

文章作者: 倪春恩
版权声明: 本博客所有文章除特別声明外,均采用 CC BY 4.0 许可协议。转载请注明来源 倪春恩 !