想要实现两个队列生成一个栈,需要先了解队列和栈的特性:
- 队列,先进先出。
- 栈,后进先出。
使用两个队列生成一个栈的实现思路为:
代码实现如下:
#!/usr/bin/env python # -*- coding:utf-8 -*- import queue class Stack(object): def __init__(self): self.master_queue = queue.Queue() self.minor_queue = queue.Queue() def push(self, value): """ 入栈 :param value: :return: """ self.master_queue.put(value) def pop(self): """ 出栈 :return: """ if self.master_queue.qsize() == 0: return None while True: if self.master_queue.qsize() == 1: value = self.master_queue.get() break self.minor_queue.put(self.master_queue.get()) self.master_queue, self.minor_queue = self.minor_queue, self.master_queue return value obj = Stack() obj.push('武沛齐') obj.push('Alex') obj.push('肖峰') print(obj.pop()) print(obj.pop()) print(obj.pop())