LeetCode155. ๆœ€ๅฐๆ ˆ๐ŸŒŸ๐ŸŒŸ๐ŸŒŸ๐ŸŒŸ๐ŸŒŸไธญ็ญ‰

้—ฎ้ข˜ๆ่ฟฐ

ๅŽŸๆ–‡้“พๆŽฅ๏ผš155. ๆœ€ๅฐๆ ˆ

่ฎพ่ฎกไธ€ไธชๆ”ฏๆŒ push ๏ผŒpop ๏ผŒtop ๆ“ไฝœ๏ผŒๅนถ่ƒฝๅœจๅธธๆ•ฐๆ—ถ้—ดๅ†…ๆฃ€็ดขๅˆฐๆœ€ๅฐๅ…ƒ็ด ็š„ๆ ˆใ€‚

ๅฎž็Žฐ MinStack ็ฑป:

  • MinStack() ๅˆๅง‹ๅŒ–ๅ †ๆ ˆๅฏน่ฑกใ€‚
  • void push(int val) ๅฐ†ๅ…ƒ็ด valๆŽจๅ…ฅๅ †ๆ ˆใ€‚
  • void pop() ๅˆ ้™คๅ †ๆ ˆ้กถ้ƒจ็š„ๅ…ƒ็ด ใ€‚
  • int top() ่Žทๅ–ๅ †ๆ ˆ้กถ้ƒจ็š„ๅ…ƒ็ด ใ€‚
  • int getMin() ่Žทๅ–ๅ †ๆ ˆไธญ็š„ๆœ€ๅฐๅ…ƒ็ด ใ€‚

็คบไพ‹ 1:

่พ“ๅ…ฅ๏ผš
["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.

ๆ็คบ๏ผš

  • -231 <= val <= 231 - 1
  • popใ€top ๅ’Œ getMin ๆ“ไฝœๆ€ปๆ˜ฏๅœจ้ž็ฉบๆ ˆไธŠ่ฐƒ็”จ
  • push, pop, top, and getMinๆœ€ๅคš่ขซ่ฐƒ็”จ 3 * 104 ๆฌก

ไปฃ็ ๅฎž็Žฐ

Java

class MinStack {
    Stack<Integer> stack1;
    Stack<Integer> stack2;

    public MinStack() {
        stack1 = new Stack();
        stack2 = new Stack();
    }

    public void push(int val) {
        stack1.push(val);
        if(stack2.isEmpty() || stack2.peek() >= val){
            stack2.push(val);
        }
    }

    public void pop() {
        if(stack1.peek().intValue() == stack2.peek().intValue()){
            stack2.pop();
        }

        stack1.pop();
    }

    public int top() {
        return stack1.peek();
    }

    public int getMin() {
        return stack2.peek();
    }
}

/**
 * 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();
 */

Python

class MinStack(object):

    def __init__(self):
        self.stack1 = []
        self.stack2 = []

    def push(self, val):
        """
        :type val: int
        :rtype: None
        """
        self.stack1.append(val)
        if not self.stack2 or self.stack2[-1] >= val:
            self.stack2.append(val)

    def pop(self):
        """
        :rtype: None
        """
        if self.stack1[-1] == self.stack2[-1]:
            self.stack2.pop()

        self.stack1.pop()

    def top(self):
        """
        :rtype: int
        """
        return self.stack1[-1]

    def getMin(self):
        """
        :rtype: int
        """
        return self.stack2[-1]

C++

class MinStack {
public:
    stack<int> stack1;
    stack<int> stack2;

    MinStack() {

    }

    void push(int val) {
        stack1.push(val);
        if(stack2.empty() || stack2.top() >= val){
            stack2.push(val);
        }
    }

    void pop() {
        if(stack1.top() == stack2.top()){
            stack2.pop();
        }

        stack1.pop();
    }

    int top() {
        return stack1.top();
    }

    int getMin() {
        return stack2.top();
    }
};

Go

type MinStack struct {
    stack1 []int
    stack2 []int
}

func Constructor() MinStack {
    return MinStack{[]int{}, []int{}}
}

func (this *MinStack) Push(val int) {
    this.stack1 = append(this.stack1, val)
    if len(this.stack2) == 0 || this.stack2[len(this.stack2)-1] >= val {
        this.stack2 = append(this.stack2, val)
    }
}

func (this *MinStack) Pop() {
    if this.stack1[len(this.stack1)-1] == this.stack2[len(this.stack2)-1] {
        this.stack2 = this.stack2[:len(this.stack2)-1]
    }

    this.stack1 = this.stack1[:len(this.stack1)-1]
}

func (this *MinStack) Top() int {
    return this.stack1[len(this.stack1)-1]
}

func (this *MinStack) GetMin() int {
    return this.stack2[len(this.stack2)-1]
}

ๅ‘่กจ่ฏ„่ฎบ

ๅŽๆ‰่ƒฝ่ฏ„่ฎบ