双端队列

双端队列(deque,全名double-ended queue),是一种具有队列和栈的性质的数据结构。
双端队列中的元素可以从两端弹出,其限定插入和删除操作在表的两端进行。双端队列可以在队列任意一端入队和出队。

  1. class Deque(object):
  2. """双端队列"""
  3. def __init__(self):
  4. self.__items = []
  5. # add_front(item) 从队头加入一个item元素
  6. def add_front(self, item):
  7. self.__items.insert(0, item)
  8. # add_rear(item) 从队尾加入一个item元素
  9. def add_rear(self, item):
  10. self.__items.append(item)
  11. # remove_front() 从队头删除一个item元素
  12. def remove_front(self):
  13. return self.__items.pop(0)
  14. # remove_rear() 从队尾删除一个item元素
  15. def remove_rear(self):
  16. return self.__items.pop()
  17. # is_empty() 判断双端队列是否为空
  18. def is_empty(self):
  19. return self.__items == []
  20. # size() 返回队列的大小
  21. def size(self):
  22. return len(self.__items)
  23. def print_items(self):
  24. print(self.__items)
  25. if __name__ == '__main__':
  26. deque = Deque()
  27. deque.add_front(1)
  28. deque.add_front(3)
  29. deque.add_front(5)
  30. deque.print_items()
  31. deque.add_rear(9)
  32. deque.add_rear(8)
  33. deque.add_rear(7)
  34. deque.print_items()
  35. print(deque.is_empty())
  36. print(deque.remove_front())
  37. print(deque.remove_rear())
  38. deque.print_items()