题目描述
用两个栈来实现一个队列,完成队列的Push
和Pop
操作。 队列中的元素为int
类型。
C++版本的初始代码为:
思路分析
用两个栈实现一个队列的功能?要求给出算法和思路!
<分析>:
入队:将元素进栈A
出队:判断栈B是否为空,如果为空,则将栈A中所有元素pop,并push进栈B,栈B出栈;如果不为空,栈B直接出栈。
换个说法:
栈A用来作入队列;栈B用来出队列,当栈B为空时,栈A全部出栈到栈B,栈B再出栈(即出队列)。
本地测试的完整C++程序:【添加了一个打印函数】
此外,还可以思考一下:
用两个队列实现一个栈的功能?要求给出算法和思路!
<分析>:
入栈:将元素进队列A
出栈:判断队列A中元素的个数是否为1,如果等于1,则出队列,否则将队列A中的元素 以此出队列并放入队列B,直到队列A中的元素留下一个,然后队列A出队列,再把队列B中的元素出队列依次放入队列A中。