想要實現兩個隊列生成一個棧,須要先了解隊列和棧的特性:python
使用兩個隊列生成一個棧的實現思路爲:blog
代碼實現以下:隊列
#!/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())