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

用两个栈实现队列

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

class Solution
{
public:
    void push(int node) {                //栈1用作实现入队
        if(stack2.empty()){           //栈2实现出队,如果栈2空,表明刚才没有进行出队动作,直接压入栈1顶端即可
            stack1.push(node);
        }
        else{
            while(stack2.size()!=0){    //如果栈2不空,则表明刚刚完成了出队动作,现在栈1是空的
                stack1.push(stack2.top());         //将栈2的元素返回栈1
                stack2.pop();
            }
            stack1.push(node);            //栈1顶端插入
        }
    }

    int pop() {
        if(!stack1.empty()){              //栈1非空,表明刚完成入队动作
            while(stack1.size()!=0){         //此时把栈1全部放到栈2中
                stack2.push(stack1.top());
                stack1.pop();
            }
            int out=stack2.top();         //弹出栈2顶端并消除即可
            stack2.pop();
            return out;
        }
        else{                          //栈2非空表明刚刚完成出队动作,连续出队即可
            int out=stack2.top();
            stack2.pop();
            return out;
        }
    }

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

全部评论

相关推荐

昨天 15:00
门头沟学院 Java
点赞 评论 收藏
分享
07-07 17:06
已编辑
深圳技术大学 golang
懒羊羊王子:能不能看一下你的简历,我想参考一下我应该学到什么程度,在面试期间你又是如何应对问题的
点赞 评论 收藏
分享
07-20 12:08
已编辑
江南大学 图像识别
机械牛马勇闯秋招:把校园经历里面做过的项目,大作业,课设,毕设啥的,扩写,写成具体的项目经历,自我评价缩写别占篇幅,不然这简历真没东西,初筛都过不了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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