news 2026/7/3 23:38:51

【python】字典数据结构的设计原理学习

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【python】字典数据结构的设计原理学习

核心结构:哈希表是一个“数组”

每个 dict 底层对应一块数组(table),数组每个槽位(slot)可能存一个 key-value。

1

2

index:01234567

value: [ ] [ ] [ ] [ ] [ ] [ ] [ ] [ ]

任何输入的key 会被哈希(hash(key))

1

2

3

4

5

6

d["abc"]=123

# python会计算

h=hash("abc") → 得到一个整数,如918273645

slot=h%table_size → 如918273645%8=5

于是 key 放到槽位 5

1

2

index:01234567

value: [ ] [ ] [ ] [ ] [ ] [('abc',123)] [ ] [ ]

如果计算出的槽位已经被占用,dict 不会链表化存储,而是 继续找下一个空槽位,其中会使用 开放寻址(Open Addressing)

1

2

slot6空? → 放这里

slot6也有人? → 看 slot7

dict 会控制“负载因子”(使用率),比如如果槽位使用率超过 ~2/3,自动扩容。扩容后空间很大,冲突变少,因此 dict 的性能保持 O(1)。

扩容操作:

  • table 大小扩成原来的 2 倍
  • 所有 key 重新哈希并放入新 table(rehash)

看具体的应用场景:使用dict进行查找、插入操作,时间复杂度是O(1)

1. 查找过程

查找d[key]

  1. 计算 hash(key)

  2. 定位槽位 slot = hash % table_size

  3. 看到槽位里是不是这个 key

    • 是 → 找到

    • 否 → 使用开放寻址规则继续探测

那么影响时间长短的,就要看hash算法的底层原理了,hash函数大致是位运算+随机化

1 adict = {} 2 adict[key]=value 3 if i not in adict: # i是否属于adict的key
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/7/1 2:42:04

计算机Java毕设实战-基于 SpringBoot 的农产品助农销售管理平台的设计与实现 基于 SpringBoot 的县域农商信息服务平台【完整源码+LW+部署说明+演示视频,全bao一条龙等】

博主介绍:✌️码农一枚 ,专注于大学生项目实战开发、讲解和毕业🚢文撰写修改等。全栈领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围:&am…

作者头像 李华
网站建设 2026/7/1 2:41:42

Java毕设项目:基于 Java 的农商产品线上推广销售平台的设计与实现 基于 Java 的农户产销对接助农管理系统 (源码+文档,讲解、调试运行,定制等)

博主介绍:✌️码农一枚 ,专注于大学生项目实战开发、讲解和毕业🚢文撰写修改等。全栈领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围:&am…

作者头像 李华
网站建设 2026/7/1 2:41:38

【计算机毕业设计案例】基于 Java 的助农农商服务平台的设计与实现 基于 Java 的乡村农产品帮扶交易系统(程序+文档+讲解+定制)

博主介绍:✌️码农一枚 ,专注于大学生项目实战开发、讲解和毕业🚢文撰写修改等。全栈领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围:&am…

作者头像 李华
网站建设 2026/7/1 2:39:59

嵌入式安全防护到底该怎么做——从硬件到固件的层层防线

三年前接了一个工业控制器的项目,客户说"安全你看着办"。结果两个月被人通过UART拿到了root shell。不是黑客多厉害,是我们根本没锁调试接口。 这事让我老实了。后来花了大量时间补这方面的功课,慢慢摸清了嵌入式安全到底在防什么…

作者头像 李华
网站建设 2026/7/1 2:39:48

用C语言和文本文件实现一个简单的,可保存的通讯录

我们先思考一个通讯录都有那些信息,很明显通讯录记录的是人 人有哪些信息呢 这里我就写5个吧,分别是姓名,年龄,电话,性别,地址 然后我们把他们写成一个结构体,最好定义在头文件里,这…

作者头像 李华
网站建设 2026/7/1 2:38:43

BetterJoy完整指南:让Switch手柄在PC游戏上完美运行

BetterJoy完整指南:让Switch手柄在PC游戏上完美运行 【免费下载链接】BetterJoy Allows the Nintendo Switch Pro Controller, Joycons and SNES controller to be used with CEMU, Citra, Dolphin, Yuzu and as generic XInput 项目地址: https://gitcode.com/gh…

作者头像 李华