Python几种数据结构内置方法的时间复杂度
参考:https://blog.csdn.net/baoli1008/article/details/48059623
注:下文中,’n’代表容器中元素的数量,’k’代表参数的值,或者参数的数量。
1.列表(list)
以完全随机的列表考虑平均情况。
列表是以数组(Array)实现的。
最大的开销发生在超过当前分配大小的增长,这种情况下所有元素都需要移动;或者是在起始位置附近插入或者删除元素,这种情况下所有在该位置后面的元素都需要移动。
如果需要在一个队列的两端进行增删的操作,应当使用collections.deque(双向队列)
操作 操作说明 时间复杂度(平均情况) 时间复杂度(最坏情况) index(value) 查找list某个元素的索引 O(1) O(1) a=index(value) 索引赋值 O(1) O(1) list[:] 列表复制 O(n) O(n) list.append(value) 队尾添加 O(1) O(1) list.insert(index, value) 根据索引插入某个元素 O(n) O(n) list[index] 取元素 O(1) O(1) list[index]=value 赋值 O(1) O(1) list.pop() 队尾删除 O(1) O(1) list.pop(index) 根据索引删除某个元素 O(n) O(n) [i for i in list] 遍历/迭代 O(n) O(n) list[m:n] 取切片 O(k) O(k) del list[m:n] 删除切片 O(n) O(n) list[m:n]=[n] 更改切片 O(k+n) O(k+n) list.extend([]) 列表扩展 O(k) O(k) list.sort() 列表排序 O(nlogn) O(nlogn) list*n 列表乘法 O(nk) O(nk) i in list 列表搜索 O(n) min(list), max(list) 取最大和最小值 O(n) len(list) 计算长度 O(1) O(1)
2.字典(dict)
- 下列字典的平均情况基于以下假设:
- 对象的散列函数足够健壮(robust),不会发生冲突。
- 字典的键是从所有可能的键的集合中随机选择的。
操作 操作说明 平均情况 最坏情况 copy 复制 O(n) O(n) dict[key] 取元素 O(1) O(n) dict[key]=value 更新元素 O(1) O(n) del dict[key] 删除元素 O(1) O(n) [i for i in dict] 遍历字典 O(n) O(n) i in dict 搜索元素 O(1) O(1)
3.集合(set)
操作 操作说明 平均情况 最坏情况 i in set 搜索元素 O(1) O(n) set_1 | set_2 并集 O(len(set_1)+len(set_2)) set_1 & set_2 交集 O(min(len(set_1), len(set_2)) O(len(set_1) * len(set_2)) set_1 - set_2 差集 O(len(set_1)) set.difference_update(set_2) 更新 O(len(set_2)) set^t 对称差集 O(len(set)) O(len(set) * len(t)) set.symmetric_difference_update(t) O(len(t)) O(len(t) * len(set))
- 差集(set_1 - set_2,或set_1.difference(set_2))运算与更新为差集(set_1.difference_uptate(set_2))运算的时间复杂度并不相同:
- 前者是将在set_1中,但不在set_2中的元素添加到新的集合中,因此时间复杂度为O(len(set_1))。
- 后者是将在set_2中的元素从set_1中移除,因此时间复杂度为O(len(set_2))。
Python几种数据结构内置方法的时间复杂度的更多相关文章
- Python 数据类型常用的内置方法(三)
目录 Python 数据类型常用的内置方法(三) 1.列表内置方法 1.sort():升序 2.reverse():颠倒顺序 3.列表比较运算 2.字典内置方法 1.对Key的操作 2.len( )- ...
- Python 数据类型常用的内置方法(二)
目录 Python 数据类型常用的内置方法(二) 1.字符串类型常用内置方法 1.upper.lower.isupper.islower 2.startswith.endswith 3.format ...
- Python 数据类型常用的内置方法(一)
目录 Python 数据类型常用的内置方法 1.整型 int 2.浮点型 float 字符串转浮点型: 3.字符串 str 多种类型转字符型: 索引 切片 len( )方法:统计字符串长度/个数 移除 ...
- 《Python》反射、内置方法(__str__,__repr__)
一.反射 通过字符串的形式操作对象相关的属性.(使用字符串数据类型的变量名来获取这个变量的值) Python中的一切事物都是对象(都可以使用反射) 反射类中的变量 反射对象中的变量 反射模板中的变量 ...
- python 面向对象反射以及内置方法
一.反射 什么是反射:可以用字符串的方式去访问对象的属性,调用对象的方法(但是不能去访问方法),python中一切皆对象,都可以使用放射. 反射的四种方法: hasattr:hasattr(objec ...
- python今日分享(内置方法)
目录 一.习题详解 二.数据类型的内置方法理论 三.整型相关操作 四.浮点型相关操作 五.字符串相关操作 六.列表相关操作 今日详解 一.习题详解 1.计算1-100所有数据之和 all_num = ...
- python 基本数据类型以及内置方法
一.数字类型 # 一.整型int # ======================================基本使用====================================== ...
- python面向对象 : 反射和内置方法
一. 反射 1. isinstance()和issubclass() isinstance( 对象名, 类名) : 判断对象所属关系,包括父类 (注:type(对象名) is 类名 : 判断对象所属 ...
- python基础之反射内置方法元类
补充内置函数 isinstance(obj,Foo) # 判断obj是不是foo的实例 issubclass() # 判断一个类是不是另一个类的子类 反射 什么是反射? 通过字符串来操作 ...
随机推荐
- lamp环境配置
一.配置虚拟域名 1.为了模拟DNS,在本地hosts文件中设置一下 2.模拟三个项目 3.在apache中配置虚拟主机 去到apache的sites-available目录里复制三次def ...
- Spark RDD Transformation 简单用例(一)
map(func) /** * Return a new RDD by applying a function to all elements of this RDD. */ def map[U: C ...
- 《JAVA编程思想》第四版 PDF 下载 中文版和英文版 高清PDF扫描带书签
一.链接: 中文版: https://pan.baidu.com/s/1d07Kp4 密码:x2cd 英文版: https://pan.baidu.com/s/1boOSdAZ 密码: rwgm 文件 ...
- 7个简单的Excel技巧,需要的赶紧get起来吧
1.直观数据图形化 2. Ctrl不连续选择 3. Ctrl+A相连文本框全选 4. 格式刷点击 5. SUM函数求和 6. 自动求和.自动求平均值.自动计数 7. 行.列距调节
- SQL中的between and
"between xx and xx "在SQL中的用法 这个大家都很熟悉,但是当问到是否包含两端的值时,就有点儿不确定了.在W3School网站上,有这样的一段话: 参考:ht ...
- {Django基础七之Ajax} 一 Ajax简介 二 Ajax使用 三 Ajax请求设置csrf_token 四 关于json 五 补充一个SweetAlert插件(了解)
Django基础七之Ajax 本节目录 一 Ajax简介 二 Ajax使用 三 Ajax请求设置csrf_token 四 关于json 五 补充一个SweetAlert插件(了解) 一 Ajax简介 ...
- python实现支持目录FTP上传下载文件的方法
#!/usr/bin/env python # -*- coding: utf-8 -*- import ftplib import os import sys class FTPSync(objec ...
- [No000010E]Git7/9-标签管理
发布一个版本时,我们通常先在版本库中打一个标签(tag),这样,就唯一确定了打标签时刻的版本.将来无论什么时候,取某个标签的版本,就是把那个打标签的时刻的历史版本取出来.所以,标签也是版本库的一个快照 ...
- [No0000C9]神秘的掐指一算是什么?教教你也会
很多朋友看到传说中诸葛亮以及那些聪明人掐指一算,惊叹不已.那些人以“察天地之理.通鬼神之志”,每次占卜时,做一大堆的神秘仪式,然后掐指一算,便大有“乾坤尽收在手”的感觉.在普通人眼里,他们的手神秘异常 ...
- MySQL获取分组后的TOP 1和TOP N记录-转
有时会碰到一些需求,查询分组后的最大值,最小值所在的整行记录或者分组后的top n行的记录,在一些别的数据库可能有窗口函数可以方面的查出来,但是MySQL没有这些函数,没有直接的方法可以查出来,可通过 ...