LeetCode实战:155. 最小栈

LeetCode实战:155. 最小栈

题目

设计一个支持 push,pop,top 操作,并能在常数时间内检索到最小元素的栈。

  • push(x) – 将元素 x 推入栈中。
  • pop() – 删除栈顶的元素。
  • top() – 获取栈顶元素。
  • getMin() – 检索栈中的最小元素。

示例:

MinStack minStack = new MinStack();
minStack.push(-2);
minStack.push(0);
minStack.push(-3);
minStack.getMin();   --> 返回 -3.
minStack.pop();
minStack.top();      --> 返回 0.
minStack.getMin();   --> 返回 -2.

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/add-two-numbers
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

算法实现

public class MinStack {
    Stack data ;
    Stack minstack;
    /** initialize your data structure here. */
    public MinStack() {
        data = new Stack();
        minstack = new Stack();
    }
    
    public void Push(int x) {
        data.Push(x);
        if(minstack.Count == 0 || x <= minstack.Peek()){
            minstack.Push(x);
        }
    }
    
    public void Pop() {
        if(data.Peek() == minstack.Peek()){
            minstack.Pop();
        }
        data.Pop();
    }
    
    public int Top() {
        return data.Peek();
    }
    
    public int GetMin() {
        return minstack.Peek();
    }
}

/**
 * Your MinStack object will be instantiated and called as such:
 * MinStack obj = new MinStack();
 * obj.Push(x);
 * obj.Pop();
 * int param_3 = obj.Top();
 * int param_4 = obj.GetMin();
 */

思路

利用两个栈,一个储存当前值,一个储存最小值。

结果

LeetCode实战:155. 最小栈_第1张图片

你可能感兴趣的:(leetcode)