题解 | #包含min函数的栈#

包含min函数的栈

http://www.nowcoder.com/practice/4c776177d2c04c2494f2555c9fcc1e49

  1. 双栈法。
  2. 注意小栈的处理。
    时间复杂度:O(1)
    空间复杂度:O(n), 开辟了一个辅助栈。
class Solution {
public:
    //双栈法解决此问题
    stack<int> stk, mins;


    void push(int value) {
        stk.push(value);
        if(mins.empty()){
            mins.push(value);
        }else{

            if(value<=mins.top()){
                mins.push(value);
            }else{
                mins.push(mins.top());
            }

        }


    }
    void pop() {
        stk.pop();//同时弹
        mins.pop();
    }
    int top() {
        return stk.top();
    }
    int min() {
        return  mins.top();
    }
};
剑指Offer 文章被收录于专栏

剑指offer的解析结合

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-01 17:13
想去,但是听说加班强度实在难崩,所以拒绝了,现在有点心梗对面hr感觉也是实习生,打电话的时候怪紧张的,但是感觉人很好嘞
水中水之下水道的鼠鼠:哥们这不先去体验一下,不行再跑呗,大不了混个实习经历(有更好的转正offer就当我没说)
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-02 17:58
点赞 评论 收藏
分享
点赞 评论 收藏
分享
求offer的大角牛:不吃香菜
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务