首页 > 开发 > Python > 正文

python双端队列原理、实现与使用方法分析

2020-07-28 13:59:17
字体:
来源:转载
供稿:网友

本文实例讲述了python双端队列原理、实现与使用方法。分享给大家供大家参考,具体如下:

双端队列

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

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

操作

Deque() 创建一个空的双端队列
add_front(item) 从队头加入一个item元素
add_rear(item) 从队尾加入一个item元素
remove_front() 从队头删除一个item元素
remove_rear() 从队尾删除一个item元素
is_empty() 判断双端队列是否为空
size() 返回队列的大小

实现

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()

更多关于Python相关内容感兴趣的读者可查看本站专题:《Python数据结构与算法教程》、《Python加密解密算法与技巧总结》、《Python编码操作技巧总结》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》及《Python入门与进阶经典教程》

希望本文所述对大家Python程序设计有所帮助。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表