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;
};