leetcode 155 最小栈

155、最小栈

1、这一道题有点意思啊,我是用了一个vector里面放了一个pair对去做的 这个pair值存了当前插入值之前对应的最小值,所以即使你出栈了数值,剩下的栈顶元素的pair的第二个仍然是当前的最小值

class MinStack {
public:
    /** initialize your data structure here. */
    vector<pair<int,int>> stk;
    
    MinStack() {        
        stk.push_back(make_pair<int,int>(0,INT_MAX));
    }
    
    void push(int x) {
        int newMin=min(x,stk[stk.size()-1].second);
        stk.push_back(make_pair(x,newMin));
    }
    
    void pop() {
        if(stk.size()>1)
            stk.pop_back();
    }
    
    int top() {
        return stk[stk.size()-1].first;
    }
    
    int getMin() {
        return stk[stk.size()-1].second;
    }
    
};

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

执行用时 :32 ms, 在所有 cpp 提交中击败了94.84%的用户
内存消耗 :17 MB, 在所有 cpp 提交中击败了34.12%的用户

下面改了一点,速度和空间都稳定的变好了

class MinStack {
public:
    /** initialize your data structure here. */
    vector<pair<int,int>> stk;
    
    MinStack() {        
        stk.push_back(make_pair<int,int>(0,INT_MAX));
    }
    
    void push(int x) {
        stk.push_back(make_pair(x,min(x,stk.back().second)));
    }
    
    void pop() {
        if(stk.size()>1)
            stk.pop_back();
    }
    
    int top() {
        return stk.back().first;
    }
    
    int getMin() {
        return stk.back().second;
    }
    
};

执行用时 :32 ms, 在所有 cpp 提交中击败了94.84%的用户
内存消耗 :16.8 MB, 在所有 cpp 提交中击败了73.22%的用户

2、然后看别人做了一个,使用两个栈做的,min栈是将最小值重复压栈,还有的就是把可能重复的最小值才重复压栈,出栈的时候就可以直接出了,比这个快,也比这个更省空间

class MinStack {
    stack<int> s1, m1;
public:
    /** initialize your data structure here. */
    MinStack() {
        
    }
    
    void push(int x) {
        s1.push(x); //s1先push一个进来
        if(m1.empty()) { //如果m1是空的,就也直接push进来
            m1.push(x);
        } else { //如果不空,保留最小值
            if(x<=m1.top()) m1.push(x);
            else m1.push(m1.top()); //这个就是把当前最小值重复压栈
        }
    }
    
    void pop() {
        s1.pop();
        m1.pop();
    }
    
    int top() {
        return s1.top();
    }
    
    int getMin() {
        return m1.top();
    }
};

执行用时 :36 ms, 在所有 cpp 提交中击败了84.40%的用户
内存消耗 :16.8 MB, 在所有 cpp 提交中击败了83.19%的用户

3、就是上面提到了那个做法

class MinStack {
private:
    stack<int> stk,minstk;
public:
    /** initialize your data structure here. */
    MinStack() {
        while(!stk.empty())stk.pop();
        while(!minstk.empty())minstk.pop();
    }
    
    void push(int x) {
        stk.push(x);
        if(minstk.empty()||x<=minstk.top())minstk.push(x);
    }
    
    void pop() {
        if(stk.empty())return;
        if(stk.top()==minstk.top())minstk.pop();
        stk.pop();
    }
    
    int top() {
        return stk.top();
    }
    
    int getMin() {
        return minstk.top();
    }
};

执行用时 :32 ms, 在所有 cpp 提交中击败了94.84%的用户
内存消耗 :16.8 MB, 在所有 cpp 提交中击败了76.84%的用户

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值