前面有道题是用队列实现栈 ,本题反过来了,是使用两个栈来模拟队列。
题解:
我们定义两个栈一个进栈in_stack,一个出栈out_stack,在push数据的时候将数据放入进栈就好,但在pop的时候,先要判断出栈是否为空,若为空的话,就把进栈的数据全部导入进来,再从出栈弹出数据,若出栈不为空,则直接从出栈弹出数据即可。判断进栈和出栈都为空,说明队列为空了。
class MyQueue:
def __init__(self):
self.in_stack = []
self.out_stack = []
def push(self, x: int) -> None:
self.in_stack.append(x)
def pop(self) -> int:
if self.empty():
return None
if self.out_stack:
return self.out_stack.pop()
else:
for _ in range(len(self.in_stack)):
self.out_stack.append(self.in_stack.pop())
return self.out_stack.pop()
def peek(self) -> int:
top = self.pop()
self.out_stack.append(top)
return top
def empty(self) -> bool:
return not(self.in_stack or self.out_stack)