python 字典 哈希_Python的字典映射使用什么哈希算法?

它使用的哈希取决于用作键的对象 – 每个类都可以定义自己的__hash __()方法,并且它为特定实例返回的值是字典使用的值.

Python本身为str和元组类型提供了哈希实现.来源的快速查看应该揭示那些准确的算法.

元组的散列是基于其内容的散列.算法基本上是这个(稍微简化):

def hash(tuple):

mult = 1000003

x = 0x345678

for index, item in enumerate(tuple):

x = ((x ^ hash(item)) * mult) & (1<<32)

mult += (82520 + (len(tuple)-index)*2)

return x + 97531

对于字符串,解释器还对每个字符进行迭代,并将其与此(再次简单的)算法相结合:

def hash(string):

x = string[0] << 7

for chr in string[1:]:

x = ((1000003 * x) ^ chr) & (1<<32)

return x

一个更大的问题是要避免哈希冲突.碰撞散列键将导致线性搜索,因为字典尝试找到一个存储新对象的位置(现在被认为是一个安全问题,并且此行为可能会在即将到来的python版本中更改)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python中,哈希算法是一种常见的数据查找算法。哈希算法通过将数据映射到一个固定大小的数字,称为哈值,来实现高效的查找。Python中有内置的哈函数hash(),可以返回对象(数字、字符串等)的哈值。例如,可以使用hash(1)来获取数字1的哈值,使用hash("abc")来获取字符串"abc"的哈值。 对于使用哈希算法解决问题的情况,可以采用双指针的解决方案。首先,对数据进行排序,然后使用双指针移动来寻找答案。最后,根据答案在原始数据中查找这两个元素的位置。然而,这种方法需要进行排序和查找,比较耗时。为了避免这个问题,可以使用哈希算法直接查找数据和下标的对应关系,而无需进行排序。 在哈希算法求解中,可以使用一个字典来存储数据的值和下标的对应关系。遍历数据列表,对于每个元素m,判断目标值减去m的结果是否在字典中,如果在字典中,则返回两个数的下标;如果不在字典中,则将当前元素m和其下标添加到字典中。通过这种方式,可以快速找到两个数字和为目标值的情况。 下面是一个使用哈希算法求解两个数字和的示例代码: ```python def twosum(nums, target): dict = {} for i in range(len(nums)): m = nums[i] if target - m in dict: return (dict[target - m], i) dict[m = i s = twosum([3, 4, 5, 7, 10], 11) print('下标是:', s) ``` 以上代码中,twosum函数可以解决两个数字和且答案有且仅有一个的情况。通过遍历列表,将每个元素及其下标添加到字典中,并判断目标值减去当前元素的结果是否在字典中,如果在字典中,则返回两个数的下标;如果不在字典中,则将当前元素及其下标添加到字典中。通过这种方式,可以快速找到两个数字和为目标值的情况。在示例代码中,给定的列表为[3, 4, 5, 7, 10],目标值为11,输出结果为(1, 3),表示下标为1和3的两个元素的和为目标值。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [Python算法系列-哈希算法](https://blog.csdn.net/weixin_42767604/article/details/105476927)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [Hash算法(含python实现)](https://blog.csdn.net/qq_14997473/article/details/81085186)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值