剑指Offer 30. 包含min函数的栈

剑指Offer
var MinStack = function() {
    this.stack = []
    // 最小值也用栈
    this.min = [Infinity]
};

/** 
 * @param {number} val
 * @return {void}
 */
MinStack.prototype.push = function(val) {
    this.stack.push(val)
    // 将最小值栈的末尾和新元素比,两者小的存在数组中
    this.min.push(Math.min(this.min[this.min.length - 1], val))
};

/**
 * @return {void}
 */
MinStack.prototype.pop = function() {
    // 同步出栈
    this.stack.pop()
    this.min.pop()
};

/**
 * @return {number}
 */
MinStack.prototype.top = function() {
    // 返回栈顶元素
    return this.stack[this.stack.length - 1]
};

/**
 * @return {number}
 */
MinStack.prototype.getMin = function() {
    // 返回最小值栈顶元素
    return this.min[this.min.length - 1]
};

/**
 * Your MinStack object will be instantiated and called as such:
 * var obj = new MinStack()
 * obj.push(val)
 * obj.pop()
 * var param_3 = obj.top()
 * var param_4 = obj.getMin()
 */
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
更新时间: 2022-03-25 17:04