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