python内置数据结构性能分析

栏目: IT技术 · 发布时间: 5年前

List

  1. 列表是一个类似数组的结构
  2. 对某个索引位置的获取和赋值的时间复杂度是O(1)
  3. 在列表末尾添加或删除一个元素的时间复杂度是O(1)
  4. 但是在列表除末尾之外的位置添加或删除一个元素的时间复杂度是O(n)。这是因为,在选定位置之后的元素需要被整体前移或后移
  5. 列表搜索的时间复杂度是O(n),因为列表搜索是靠遍历元素完成的
  6. 列表的extend时间复杂度是O(k),相当于在列表末尾插入k个元素
  7. 列表的sort函数内部实现机制为timesort,时间复杂度为O(nlogn),空间复杂度为O(n),是一种稳定的 排序 方法
    python内置数据结构性能分析

Dict

  1. 字典的底层实现是哈希表
  2. 字典是无序的,但可以使用collections.OrderedDict()实现有序字典。OrderedDict的实现原理是哈希表+双链表
  3. 字典的增删改查都是O(1)的时间复杂度
    python内置数据结构性能分析

Set

  1. 集合的底层实现是哈希表
  2. 集合的增删改查与字典一样,都是O(1)的时间复杂度
    python内置数据结构性能分析

collections.deque

  1. 双向队列的底层实现是双链表
  2. 一种对列表的改进:在头尾的增删都是O(1)的时间复杂度
  3. 但是在队列中的增删仍是O(n)的时间复杂度
  4. 查找也是O(n)的时间复杂度
    python内置数据结构性能分析

参考资料

https://runestone.academy/runestone/books/published/pythonds/AlgorithmAnalysis/Lists.html


以上所述就是小编给大家介绍的《python内置数据结构性能分析》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Ajax修炼之道

Ajax修炼之道

(美)哥特兰、高伯瑞斯、艾米亚 / 徐锋,胡冰 / 电子工业出版社 / 2006-4 / 29.8

Ajax将静态Web页面转变为充满交互的应用。现在您不需要牺牲Web应用程序部署的简单性,就可以将“胖”客户端应用程序部署到客户端。不过对于很多人业说,Ajax看起来很难。这就是我们撰写本书的原因。作为实践的指导,本书揭开了Ajax神秘的面纱,教您如何以简单的方式使用Ajax。本书内容覆盖了DHTML、Javascript和闻名已久的XmlHttp Request回调技术的基础知识。您将了解如何将......一起来看看 《Ajax修炼之道》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具