舍侠 发表于 2022-4-29 11:10:54

38讲习题3

>>> d = {}
>>> d = "千年王八"
>>> d = "万年龟"
>>> d
{1: '万年龟'}
>>> 这个结果怎么是这样呢
d代表键,d代表值吗

isdkz 发表于 2022-4-29 11:12:38

字典中不会有重复的键,因为 1 和 1.0 的值相同,

所以后面的值覆盖了前面的

舍侠 发表于 2022-4-29 11:13:55

isdkz 发表于 2022-4-29 11:12
字典中不会有重复的键,因为 1 和 1.0 的值相同,

所以后面的值覆盖了前面的

不理解d和d这是什么意思?位置?

wp231957 发表于 2022-4-29 11:15:20

舍侠 发表于 2022-4-29 11:13
不理解d和d这是什么意思?位置?

字典属于key-value型数据,具体可以百度
这里的1和1.0都属于key   而后面的乌龟什么的就是value

isdkz 发表于 2022-4-29 11:15:45

舍侠 发表于 2022-4-29 11:13
不理解d和d这是什么意思?位置?

字典没有位置,只有键和值,d 和 d 都表示 字典 d 中键为 1 的值

舍侠 发表于 2022-4-29 11:19:05

isdkz 发表于 2022-4-29 11:15
字典没有位置,只有键和值,d 和 d 都表示 字典 d 中键为 1 的值

d和d都表示字典d里面键为1的值是吧?

isdkz 发表于 2022-4-29 11:20:13

舍侠 发表于 2022-4-29 11:19
d和d都表示字典d里面键为1的值是吧?

嗯嗯,因为 1 == 1.0 为 True,所以字典就认为这两个是同一个键

Twilight6 发表于 2022-4-29 11:21:13



因为字典底层是使用散列表进行存取的,即 key 值是通过计算 哈希 值来进行确定数据索引位置的

而 1 和 1.0 的 哈希值相同,所以才导致他们两个存储的位置是同一个索引,最终导致数据的覆盖

>>> print(hash(1) == hash(1.0))
True

isdkz 发表于 2022-4-29 11:27:16

Twilight6 发表于 2022-4-29 11:21
因为字典底层是使用散列表进行存取的,即 key 值是通过计算 哈希 值来进行确定数据索引位置的

而 1...

好的,谢谢大佬纠正{:5_109:}
页: [1]
查看完整版本: 38讲习题3