Please enable Javascript to view the contents

剑指office(二十)包含min函数的栈

 ·  ☕ 1 分钟  ·  🎅 YSL

题目描述

定义栈的数据结构,请在该类型中实现一个能够得到栈中所含最小元素的min函数(时间复杂度应为O(1))。

 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
class Solution {
public:
    stack<int> v;
    stack<int> minV;
    void push(int value) {
        v.push(value);
        if(minV.empty())
            minV.push(value);
        if(minV.top()>value)
        {
           minV.push(value);
        }
    }
    void pop() {
        if(v.top()==minV.top())
            minV.pop();
        v.pop();
    }
    int top() {
        return v.top();
    }
    int min() {
        return minV.top();
    }
};