加入收藏 | 设为首页 | 会员中心 | 我要投稿 PHP编程网 - 黄冈站长网 (http://www.0713zz.com/)- 数据应用、建站、人体识别、智能机器人、语音技术!
当前位置: 首页 > 运营中心 > 建站资源 > 优化 > 正文

Python编程中3个常用的数据结构和算法

发布时间:2019-04-16 01:22:21 所属栏目:优化 来源:程序员爱学习
导读:副标题#e# Python内置了许多非常有用的数据结构,比如列表(list)、集合(set)以及字典(dictionary)。就绝大部分情况而言,我们可以直接使用这些数据结构。但是,通常我们还需要考虑比如搜索、排序、排列以及筛选等这一类常见的问题。 本篇文章将介绍3种常见

deque(maxlen=N)创建了一个固定长度的队列。当有新记录加入而队列已满时会自动移除最老的那条记录。例如:

  1. >>> q = deque(maxlen=3) 
  2. >>> q.append(1) 
  3. >>> q.append(2) 
  4. >>> q.append(3) 
  5. >>> q 
  6. deque([1, 2, 3], maxlen=3) 
  7. >>> q.append(4) 
  8. >>> q 
  9. deque([2, 3, 4], maxlen=3) 
  10. >>> q.append(5) 
  11. >>> q 
  12. deque([3, 4, 5], maxlen=3) 

尽管可以在列表上手动完成这样的操作(append、del),但队列这种解决方案要优雅得多,运行速度也快得多。

更普遍的是,当需要一个简单的队列结构时,deque可祝你一臂之力。如果不指定队列的大小,也就得到了一个无界限的队列,可以在两端执行添加和弹出操作,例如:

  1. >>> q = deque() 
  2. >>> q.append(1) 
  3. >>> q.append(2) 
  4. >>> q.append(3) 
  5. >>> q 
  6. deque([1, 2, 3]) 
  7. >>> q.appendleft(4) 
  8. >>> q 
  9. deque([4, 1, 2, 3]) 
  10. >>> q.pop() 
  11. >>> q 
  12. deque([4, 1, 2]) 
  13. >>> q.popleft() 

从队列两端添加或弹出元素的复杂度都是O(1)。这和列表不同,当从列表的头部插入或移除元素时,列表的复杂度为O(N)。

【编辑推荐】

  1. Stack Overflow 2019开发者调查报告发布,Python或成赢?
  2. Fedora 提出统一流程,弃用上千 Python 2 软件包更可控
  3. Python并发:线程和锁
  4. 百道Python面试题实现,搞定Python编程就靠它
  5. 你爱 “Python”的身体,还是“R”的灵魂?
【责任编辑:赵宁宁 TEL:(010)68476606】
点赞 0

(编辑:PHP编程网 - 黄冈站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

热点阅读