zhouzhaoxin
zhouzhaoxin 主攻python,喜欢读书,喜欢摄影,芒格的忠实追随者。关注各个领域发展,取长补短,擅长结合多学科技术解决问题

数据结构与算法-双端队列

数据结构与算法-双端队列

双端队列(deque,全名double-ended queue),是一种具有队列和栈的性质的数据结构。

双端队列中的元素可以从两端弹出,其限定插入和删除操作在表的两端进行。双端队列可以在队列任意一端入队和出队。

maven

操作

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