Python内置方法的时间复杂度
来源:互联网 发布:za的护肤品怎么样知乎 编辑:程序博客网 时间:2024/06/05 14:13
本文转载自橘子一方的N维空间,特别表示感谢!
本文翻译自Python Wiki
本文基于GPL v2协议,转载请保留此协议。
本页面涵盖了Python中若干方法的时间复杂度(或者叫“大欧”,“Big O”)。该时间复杂度的计算基于当前(译注:至少是2011年之前)的CPython实现。其他Python的实现(包括老版本或者尚在开发的CPython实现)可能会在性能表现上有些许小小的差异,但一般不超过一个O(log n)项。
本文中,’n’代表容器中元素的数量,’k’代表参数的值,或者参数的数量。
列表(list)
以完全随机的列表考虑平均情况。
列表是以数组(Array)实现的。最大的开销发生在超过当前分配大小的增长,这种情况下所有元素都需要移动;或者是在起始位置附近插入或者删除元素,这种情况下所有在该位置后面的元素都需要移动。如果你需要在一个队列的两端进行增删的操作,应当使用collections.deque(双向队列)
双向队列(collections.deque)
deque (double-ended queue,双向队列)是以双向链表的形式实现的 (Well, a list of arrays rather than objects, for greater efficiency)。双向队列的两端都是可达的,但从查找队列中间的元素较为缓慢,增删元素就更慢了。
集合(set)
未列出的操作可参考 dict —— 二者的实现非常相似。
由源码得知,求差集(s-t,或s.difference(t))运算与更新为差集(s.difference_uptate(t))运算的时间复杂度并不相同!前者是将在s中,但不在t中的元素添加到新的集合中,因此时间复杂度为O(len(s));后者是将在t中的元素从s中移除,因此时间复杂度为O(len(t))。因此,使用时请留心,根据两个集合的大小以及是否需要新集合来选择合适的方法。
集合的s-t运算中,并不要求t也一定是集合。只要t是可遍历的对象即可。
字典(dict)
下列字典的平均情况基于以下假设:
1. 对象的散列函数足够撸棒(robust),不会发生冲突。
2. 字典的键是从所有可能的键的集合中随机选择的。
小窍门:只使用字符串作为字典的键。这么做虽然不会影响算法的时间复杂度,但会对常数项产生显著的影响,这决定了你的一段程序能多快跑完。
注:
[1] = These operations rely on the “Amortized” part of “Amortized Worst Case”. Individual actions may take surprisingly long, depending on the history of the container.
[2] = For these operations, the worst case n is the maximum size the container ever achieved, rather than just the current size. For example, if N objects are added to a dictionary, then N-1 are deleted, the dictionary will still be sized for N objects (at least) until another insertion is made.
- Python内置方法的时间复杂度
- Python内置方法的时间复杂度
- Python:内置方法的时间复杂度
- PYTHON内置方法的时间复杂度
- Python 各种集合内置方法的时间复杂度
- 时间复杂度和空间复杂度&排序方法的python实现【整理】
- python的内置方法
- Python的内置方法
- 算法的时间复杂度和空间复杂度的求解方法
- 估算递归问题的时间复杂度方法
- 关于如何计算时间复杂度的方法!
- 基本查询方法的时间复杂度
- 算法的时间复杂度推导方法
- Python强大的内置方法
- Python 的内置字符串方法
- Python---字符串的内置方法
- python-类的内置方法
- [python] 类常用的内置方法
- android 面试题总结
- Java—可变参数
- java: Compilation failed: internal java compiler error
- Gym 100646H You’ll be Working on the Railroad(搜索)
- 事件冒泡解决方案
- Python内置方法的时间复杂度
- java内存分配
- python 图像的显示关闭以及保存
- 一致性哈希
- Android——关于android6.0的权限问题
- python关于计时
- MyBatis通用dao和通用service
- Android 6.0 运行时权限检查分析
- GNU ARM 汇编指令