以下是自己的学习记录,算是一个总结。

接下来会依次对下面问题做一个解答:

1. Python的dict和set为什么是无序的?

2. 为什么不是所有的python对象都可以用作dict的键和set中的元素

要弄懂上面的问题,我们首先要了解Python内部是如何实现dict和set类型的。我们先来看看dict的内部结构,dict其实本质上是一个散列表(散列表即总有空白元素的数组,Python会保证至少有三分之一的数组元素是空的),dict的每个键都占用一个表元,而一个表元中又分为两个部分,分别是对键的引用和对值的引用。当我们存放一个对象的时候,首先会要计算这个元素的散列值,python中使用hash()方法来实现的,这也就回答了第二个问题,因为不是所有的python对象都可以使用hash来获取散列值,获取不到散列值也就不可能存放到dict中,所以只有可hash的对象才能够作为dict的键。值得注意的是内置的hash方法可以用于所有的内置类型对象的,所有用户自定义的对象默认都是可以作为键的,因为自定义对象的散列值是通过id()来获取的。例如:

class T(object):

pass

t = T()

print(id(t))

d = {t: 1}

print(d)

### 2133693018240

### {<__main__.t object at>: 1}

现在假设我们已经获取到了元素的散列值,接下来就该计算应当存放位置了,将散列值对数组长度进行取余,得到的结果就是存放位置的索引了。但是不同的key可能会得到相同的散列值,也就是哈希冲突的问题,python内部是使用开放寻址的方法来解决的,开放寻址法就不在此详细说了。关于为什么dict是无序的,这个是因为python内部会保证散列表至少有三分之一的位置为空,当我们增加元素的时候,python有可能会对散列表进行扩容,具体操作就是重新开辟一块更大的空间,将原有的元素添加到新表里面,这个过程中可能又会发生新的散列冲突,导致新的散列表中的键的次序发生变化。当然呢如果想要保存顺序也可以使用OrderedDict来处理

dict操作的时间复杂度:

操作

操作说明

时间复杂度copy

复制

O(n)

get(value)

获取

O(1)

set(value)

修改

O(1)

delete(value)

删除

O(1)

search(in)

字典搜索

O(1)

iterration

字典迭代

O(n)

set集合和dict一样也是基于散列表的,只是他的表元只包含值的引用而没有对键的引用,其他的和dict基本上是一致的,所以在此就不再多说了。

python字典的实现原理_Python字典的实现原理相关推荐

  1. python字典如何删除数据库_Python 字典删除元素clear、pop、popitem

    同其它python内建数据类型一样,字典dict也是有一些实用的操作方法.这里我们要说的是字典删除方法:clear().pop()和popitem(),这三种方法的作用不同,操作方法及返回值都不相同. ...

  2. python字典里存字符_Python字典和字符串的学习

    学习Python的字典还是和oc的字典进行对比学习,首先我们来创建一个字典.根据oc中字典一样,字典是无序的,根据键来进行取值. oc: oc中的字典分为可变字典和不可变字典,在对字典进行增,删的时候 ...

  3. python字典添加主键_python 字典相关操作

    Python 中的一种数据结构 -- 字典( Dictionary )的使用方法总结. 一. dictionary 数据类型的结构是: {key1:value1, key2:value2, ...} ...

  4. python字典与json转换_python字典与json转换的方法总结

    在python中json分别由列表和字典组成,本文主要介绍python中字典与json相互转换的方法.使用json.dumps可以把字典转成json字符串.使用json.loads可以把json字符串 ...

  5. python字典怎么添加值_python字典中如何添加键值对

    添加键值对 首先定义一个空字典 1 >>> dic={} 直接对字典中不存在的key进行赋值来添加 1 2 3 >>> dic['name']='zhangsan' ...

  6. python字典统计单词个数_python字典统计单词个数

    python 字典中的词频统计之后 如何将频数大于一个比如a出现了10次,b15次,c20次,d25次,CSS布局HTML小编今天和大家分享频数大于14的词的个数,应该v={} for i in di ...

  7. python字典操作的方法_python 字典操作方法详解

    python 字典操作方法详解 一.总结 一句话总结: 字典就是键值对映射 ,像js和php中的键值对数组:{'name':'jamnes','age':'32'} 1.python字典的增删改查? ...

  8. python字典键值唯一_python字典操作详解

    python字典是一个无序.以键值对存储的数据类型,数据关联性强.唯一一个映射数据类型.键:必须是可哈希(不可变的数据类型:字符串.数字.元组.bool)值,并且是唯一的 None: none 是一个 ...

  9. python字典按键值排序_Python字典『键 值』排序

    假设有一个字符串,然后想要查一下每个字母出现了多少次,可以通过字典来实现,实现方法? 用了get方法,来编写一下histogram这个函数,去掉那些if语句,更简洁一下: def histogram( ...

最新文章

  1. ios pusher使用_如何使用JavaScript和Pusher实时更新用户状态
  2. windows2008C盘清理
  3. python 编译器pyc_有没有办法知道哪个Python版本.pyc文件被编译?
  4. c语言宿舍管理设计报告,C语言课程设计—学生宿舍管理系统设计报告.doc
  5. SVN:retrieval of mergeinfo unsupported by
  6. Python 基础 —— re:正则表达
  7. sudoku me_Java Sudoku解算器程序
  8. (译)响应式图片— srcset 和 sizes 属性
  9. 工商银行c语言笔试题,【中国工商银行研发软件笔试试题及答案】 - 面试网
  10. 谢耳朵用的MIT人工智能情绪探测器,你也可以拥有
  11. Qt tableWidget导入\导出Excel表格
  12. MySQL增删改查及备份恢复
  13. 薇娅,李佳琦都点赞的淘宝双11直播系统,是如何打造的?
  14. 服务器必备工具软件推荐
  15. LEETCODE838java
  16. leetcode总结
  17. CPU、GPU、TPU的原理简述及其区别
  18. SSCNet环境搭建
  19. 如何在 JavaScript 中检查数字是正数还是负数
  20. 【云原生 | 从零开始学Docker】一、Docker的安装,启动以及工作原理

热门文章

  1. 登顶CLUE榜单,腾讯云小微与腾讯AI Lab联合团队提出基于知识的中文预训练模型...
  2. 46 万奖金等你拿 | 微众银行第二届金融科技高校技术大赛报名中
  3. 科学家都解决不了的5个“简单”算法,你不来看看?
  4. 圆圈中最后剩下的数字
  5. K-近邻算法之案例:鸢尾花种类预测—流程实现
  6. 计算机操作系统第四版习题答案 第一章简答题
  7. 复习计算机网络基础 day8--传输层
  8. 网络工程师_想要记录下来的一些题_2
  9. 基于交换技术的网络中,全双工主要运行在?( 内有答案与详解)
  10. ACMNO.20 C语言-插入队列 已有一个已排好的9个元素的数组,今输入一个数要求按原来排序的规律将它插入数组中。 输入 第一行,原始数列。 第二行,需要插入的数字。