题目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全为空表示队列为空。