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

包含min函数的栈

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

#include<algorithm>
#include <functional>
class Solution {
public:
    int Minnum;
    stack<int> s1,s2;
    // s1正常pop top push 
    // s2存最小值
    void push(int value) {
        s1.push(value);
        //s2为空
        if(s2.empty() || value < s2.top())
        {
            s2.push(s1.top());
        }
        else
        {
            s2.push(s2.top());
        }
    }
    void pop() {
        s1.pop();
        s2.pop();
    }
    int top() {
        return s1.top();
    }
    //获取栈中最小元素
    int min() {
        return s2.top();
    }
};

用两个栈实现,一个栈正常pop、push、top操作

另一个栈存当前最小值,如果每次push的值小于s2栈顶的元素则push进来

s2为空也要给它push一个值进去。

#C++面试题#
全部评论

相关推荐

屌丝逆袭咸鱼计划:心态摆好,man,晚点找早点找到最后都是为了提升自己好进正职,努力提升自己才是最关键的😤难道说现在找不到找的太晚了就炸了可以鸡鸡了吗😤早实习晚实习不都是为了以后多积累,大四学长有的秋招进的也不妨碍有的春招进,人生就这样
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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