题解 | 包含MIN函数的栈

包含min函数的栈

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

辅助栈关键在于每次都有入栈,入栈元素为最小元素,个数与s保持一致

private:
    stack<int> s,minStack;
public:
    void push(int value) {
        if(minStack.empty()){
            minStack.push(value);
        }
        s.push(value);
        if(minStack.empty()){
            minStack.push(value);
        }
        else{
            if(minStack.top()>value)
                minStack.push(value);
            else
                minStack.push(minStack.top());//每次让当前栈最小值入栈
        }
    }
    void pop() {
        s.pop();
        minStack.pop();
    }
    int top() {
        return s.top();
    }
    int min() {
        return minStack.top();
    }
};
全部评论

相关推荐

owwhy:难,技术栈在嵌入式这块显得非常浅,并且简历有大问题。教育经历浓缩成两行就行了,写什么主修课程,说的不好听这块没人在意,自我评价删了,项目写详细点,最终简历缩成一页。相关技能怎么说呢,有点差了,还写成这么多行
投了多少份简历才上岸
点赞 评论 收藏
分享
LZHR:老哥你从投递简历测评完到一面中间隔了多久呀,我这边已经过了五天了仍显示简历筛选中是不是就是挂了
腾讯求职进展汇总
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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