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