题解 | #包含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的解析结合

全部评论

相关推荐

鲸鸿:实习协议不用管签多久,要走的时候提前三天说就可以了
点赞 评论 收藏
分享
在打卡的大老虎很想潜...:你在找实习,没啥实习经历,技术栈放前面,项目多就分两页写,太紧凑了,项目你最多写两个,讲清楚就行,项目背景。用到的技术栈、亮点、难点如何解决,人工智能进面太难了,需求少。你可以加最新大模型的东西
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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