Python 字典是哈希表的一个示例吗?

2025-03-05 09:14:00
admin
原创
102
摘要:问题描述:Python 中的基本数据结构之一是字典,它允许记录“键”以查找任何类型的“值”。这是在内部实现为哈希表吗?如果不是,它是什么?解决方案 1:是的,它是一个哈希映射或哈希表。您可以在此处阅读 Tim Peters 撰写的有关 Python 的 dict 实现的描述。这就是为什么你不能使用“不可哈希”...

问题描述:

Python 中的基本数据结构之一是字典,它允许记录“键”以查找任何类型的“值”。这是在内部实现为哈希表吗?如果不是,它是什么?


解决方案 1:

是的,它是一个哈希映射或哈希表。您可以在此处阅读 Tim Peters 撰写的有关 Python 的 dict 实现的描述。

这就是为什么你不能使用“不可哈希”的东西作为字典键,比如列表:

>>> a = {}
>>> b = ['some', 'list']
>>> hash(b)
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
TypeError: list objects are unhashable
>>> a[b] = 'some'
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
TypeError: list objects are unhashable

您可以阅读有关哈希表的更多信息或检查它在 Python 中是如何实现的以及为什么以这种方式实现。

解决方案 2:

Python 字典肯定不止 hash() 上的表查找。通过强力实验,我发现了以下哈希碰撞

>>> hash(1.1)
2040142438
>>> hash(4504.1)
2040142438

但它并没有破坏字典:

>>> d = { 1.1: 'a', 4504.1: 'b' }
>>> d[1.1]
'a'
>>> d[4504.1]
'b'

健全性检查:

>>> for k,v in d.items(): print(hash(k))
2040142438
2040142438

可能除了 hash() 之外还有另一个查找级别可以避免字典键之间的冲突。或者 dict() 可能使用不同的哈希值。

(顺便说一下,这是在 Python 2.7.10 中发生的。在 Python 3.4.3 和 3.5.0 中也发生了同样的情况,但在 处发生了碰撞hash(1.1) == hash(214748749.8)。)

(我没有在 Python 3.9.6 中发现任何冲突。由于哈希值更大hash(1.1) == 230584300921369601——我估计我的桌面需要一千年才能找到一个。所以我会就此事回复你。)

解决方案 3:

是的。它的内部实现是基于 Z/2 上的本原多项式的开放哈希算法 (来源)。

解决方案 4:

扩展 nosklo 的解释:

a = {}
b = ['some', 'list']
a[b] = 'some' # this won't work
a[tuple(b)] = 'some' # this will, same as a['some', 'list']
相关推荐
  政府信创国产化的10大政策解读一、信创国产化的背景与意义信创国产化,即信息技术应用创新国产化,是当前中国信息技术领域的一个重要发展方向。其核心在于通过自主研发和创新,实现信息技术应用的自主可控,减少对外部技术的依赖,并规避潜在的技术制裁和风险。随着全球信息技术竞争的加剧,以及某些国家对中国在科技领域的打压,信创国产化显...
工程项目管理   4008  
  为什么项目管理通常仍然耗时且低效?您是否还在反复更新电子表格、淹没在便利贴中并参加每周更新会议?这确实是耗费时间和精力。借助软件工具的帮助,您可以一目了然地全面了解您的项目。如今,国内外有足够多优秀的项目管理软件可以帮助您掌控每个项目。什么是项目管理软件?项目管理软件是广泛行业用于项目规划、资源分配和调度的软件。它使项...
项目管理软件   2751  
  本文介绍了以下10款项目管理软件工具:禅道项目管理软件、Freshdesk、ClickUp、nTask、Hubstaff、Plutio、Productive、Targa、Bonsai、Wrike。在当今快速变化的商业环境中,项目管理已成为企业成功的关键因素之一。然而,许多企业在项目管理过程中面临着诸多痛点,如任务分配不...
项目管理系统   86  
  本文介绍了以下10款项目管理软件工具:禅道项目管理软件、Monday、TeamGantt、Filestage、Chanty、Visor、Smartsheet、Productive、Quire、Planview。在当今快速变化的商业环境中,项目管理已成为企业成功的关键因素之一。然而,许多项目经理和团队在管理复杂项目时,常...
开源项目管理工具   97  
  本文介绍了以下10款项目管理软件工具:禅道项目管理软件、Smartsheet、GanttPRO、Backlog、Visor、ResourceGuru、Productive、Xebrio、Hive、Quire。在当今快节奏的商业环境中,项目管理已成为企业成功的关键因素之一。然而,许多企业在选择项目管理工具时常常面临困惑:...
项目管理系统   85  
热门文章
项目管理软件有哪些?
曾咪二维码

扫码咨询,免费领取项目管理大礼包!

云禅道AD
禅道项目管理软件

云端的项目管理软件

尊享禅道项目软件收费版功能

无需维护,随时随地协同办公

内置subversion和git源码管理

每天备份,随时转为私有部署

免费试用