队列实现栈原理是什么?队列实现栈方案有哪几种?

描述

1、队列实现栈原理简述

栈是一种后进先出的数据结构,而队列是一种先进先出的数据结构,两者原理不难理解,使用也简单。但是我们不仅仅要掌握数据结构的基本原理,还要学会灵活运用,能否灵活运用是考察一个人对数据结构的理解程度,也是在面试的时候经常会考到的知识点。现在假设面试官要求你用队列实现栈,你的解决方案是什么?通过栈的基本原理我们知道,只要每次进行stack_pop操作时将队列里最后一个元素输出就能模拟栈的输出操作。

2、队列实现栈方案和实现

方案1:

我们很容易想到一种解决方案,队列queue1保存原始输入数据,队列queue2作为临时队列缓存数据,只要进行stack_pop操作时,先将queue1里除最后一个元素外全部出队,且出队的数据保存在一个临时队列queue2里,保存queue1最后的元素,最后再将queue2里的全部元素出队,且出队的元素重新放进queue1里,返回保存的queue1最后的元素。

我们作了下图便于理解2个队列模拟栈的过程。

一个栈输出元素顺序

元素

两个队列queue1和queue2模拟栈

元素

在数据结构与算法篇-队列和数据结构与算法篇-栈文章里我们详细介绍了队列和栈的原理,并都用C实现了队列和栈。现在我们复用这两篇文章里队列的实现代码,用于实现栈。定义栈相关数据结构和操作函数代码如下:

元素

栈初始化函数实现:

元素

栈销毁函数实现:

元素

入栈函数实现:

元素

出栈函数实现:

元素

判断栈是否空和是否满函数实现:

元素

从方案1我们知道每次出队都需要将队列里除最后一个元素外的元素保存在另外一个临时队列里,增加了空间复杂度。那么能否只用一个队列能否模拟栈呢?通过仔细观察方案1发现queue1出对的数据是可以重新再入队的,只要让队列里最后一个元素在队列头即可,那么我们很容易想到方案2。 方案2: 将队列queue1里的数据依次出队,且出队的数据重新放在queue1的队尾,直到最后一个元素在队列头,最后输出队列头的元素即可。整个过程我们可以用下图表示。单个队列模拟栈

元素

单个队列模拟出栈函数实现如下:

元素

栈实现验证

下面我们写一个小程序验栈实现的正确性。

元素

编译运行输出如下:  

元素

队列模拟栈完全正确。

责任编辑:lq6

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分