题解 | #用两个栈实现队列#

用两个栈实现队列

https://www.nowcoder.com/practice/54275ddae22f475981afa2244dd448c6

//定义两个栈,保证一个只进,一个只出
class Solution
{
public:
    void push(int node) {{
            stack1.push(node);
        }
        
    }

    int pop() {
        if (stack2.empty()&&stack1.empty()) {
            return -1;
        }
        else if (stack2.empty()) {
            while (!stack1.empty()) {
                int num=stack1.top();
                stack2.push(num);
                stack1.pop();
            }
            int re =stack2.top();
            stack2.pop();
            return re;
        }
        else {
            int re =stack2.top();
            stack2.pop();
            return re;
        }
    }

private:
    stack<int> stack1;
    stack<int> stack2;
};

全部评论

相关推荐

拉丁是我干掉的:把上海理工大学改成北京理工大学。成功率增加200%
点赞 评论 收藏
分享
预计下个星期就能开奖吧,哪位老哥来给个准信
华孝子爱信等:对接人上周说的是这周
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务