09-用两个栈实现队列

题目1:用两个栈实现一个队列

 

class Stack2Queue(object):
    def __init__(self):
        self.stack1 = []
        self.stack2 = []
    def push(self,var):
        self.stack1.append(var)
    def pop(self):
        if len(self.stack2)>0:
            return self.stack2.pop()
        else:
            while len(self.stack1)>0:
                self.stack2.append(self.stack1.pop())
            return self.stack2.pop()
    def empty(self):
        if len(self.stack2)==0 and len(self.stack1)==0:
            return True
        else:
            return False

注:

一个栈用来模拟入队,另一个栈模拟出队。如果栈2为空,从栈1将数据移到栈2。栈1和栈2全为空表示队列为空。

posted @ 2019-08-12 20:38  尘世中一个迷途小书童  阅读(104)  评论(0编辑  收藏  举报