用两个栈模拟队列

本文介绍如何利用两个栈模拟实现队列的功能,详细解释了push和pop操作的逻辑,并给出了具体的C++代码实现。在push过程中,元素直接进入栈1;在pop过程中,若栈2非空直接弹出,否则将栈1的所有元素转移到栈2再弹出栈2顶部元素,确保先进先出的原则。
摘要由CSDN通过智能技术生成
  • List item

用两个栈来实现一个队列

栈:栈特点是后进先出,即最后push进的元素最早pop出来。
队列:队列的特点是先进先出,第一个进入队列的元素将第一个出来

c++ STL 中有stack和queue的定义,使用方法为:

stack<int> a;
queue<string> q;

stack的重要的函数:

empty() 堆栈为空则返回真
pop() 移除栈顶元素 (尤其注意的是pop不返回栈顶元素)
push() 在栈顶增加元素
size() 返回栈中元素数目
top() 返回栈顶元素

queue的重要函数:

push()在队尾增加元素
pop()将队首元素移去 注意:返回值为void,不返回队首元素
size()返回队列中元素数目
empty()判断队列是否为空
fron

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值