用两个栈实现队列-创新互联
利用两个栈实现队列的先进先出
本文题目:用两个栈实现队列-创新互联
文章地址:http://myzitong.com/article/dgeipj.html
图片演示:
1.将前四个元素压入栈1
![](/upload/otherpic31/12cbafcdde013565c73b181ca1a1a337.jpg)
2.将栈1元素出栈压入栈2
![](/upload/otherpic31/b8892645555387a104e76fde46843173.jpg)
3.将栈2顶部元素出栈相当于出队
![](/upload/otherpic31/fbf9e3141d0df574be3b80977b749441.jpg)
4.将栈2元素出栈压入栈1
![](/upload/otherpic31/eaf6bdd954cb8956df584406cf6ba236.jpg)
5.将队列最后一个元素压入栈1
![](/upload/otherpic31/fb47781c035aa6771a2c675ec425245d.jpg)
代码部分(c++实现):
class CQueue {
public:
stackstack1;
stackstack2;
CQueue() {
}
void appendTail(int value) {
stack1.push(value);
}
int deleteHead() {
if(stack1.empty()) return -1;
while(!stack1.empty())
{
int tmp=stack1.top();
stack1.pop();
stack2.push(tmp);
}
int res=stack2.top();
stack2.pop();
while(!stack2.empty())
{
int tmp=stack2.top();
stack2.pop();
stack1.push(tmp);
}
return res;
}
};
你是否还在寻找稳定的海外服务器提供商?创新互联www.cdcxhl.cn海外机房具备T级流量清洗系统配攻击溯源,准确流量调度确保服务器高可用性,企业级服务器适合批量采购,新人活动首月15元起,快前往官网查看详情吧
本文题目:用两个栈实现队列-创新互联
文章地址:http://myzitong.com/article/dgeipj.html