ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

解决Hash冲突(碰撞)四种方法

2022-03-26 18:02:22  阅读:631  来源: 互联网

标签:Hash key 碰撞 37 地址 冲突 哈希 散列 四种


Hash算法解决冲突的常用解决方法:
1、 开放定址法: 
所谓的开放定址法就是一旦发生了冲突,就去寻找下一个空的散列地址,只要散列表足够大,空的散列地址总能找到,并将记录存入公式为:
  fi(key) = (f(key)+di) MOD m (di=1,2,3,……,m-1) 
※ 做法是:当冲突发生时,使用某种探测技术在散列表中形成一个探测序列。

沿此序列逐个单元地查找,直到找到给定的关键字,或者碰到一个开放的地址(即该地址单元为空)为止(若要插入,在探查到开放的地址,则可将待插入的新结点存人该地址单元)。 
查找时探测到开放的地址则表明表中无待查的关键字,即查找失败。 

比如说,我们的关键字集合为{12,67,56,16,25,37,22,29,15,47,48,34},表长为12。

我们用散列函数f(key) = key mod l2 
当计算前S个数{12,67,56,16,25}时,都是没有冲突的散列地址,直接存入: 

这里写图片描述

2、再哈希法: 

再哈希法又叫双哈希法,有多个不同的Hash函数,当发生冲突时,使用第二个,第三个,….,等哈希函数
计算地址,直到无冲突。虽然不易发生聚集,但是增加了计算时间。

3、链地址法: 
链地址法的基本思想是:每个哈希表节点都有一个next指针,多个哈希表节点可以用next指针构成一个单向链表,被分配到同一个索引上的多个节点可以用这个单向链表连接起来,如:
键值对k2, v2与键值对k1, v1通过计算后的索引值都为2,这时及产生冲突,但是可以通道next指针将k2, k1所在的节点连接起来,这样就解决了哈希的冲突问题。
这里写图片描述
4、建立公共溢出区: 
这种方法的基本思想是:将哈希表分为基本表和溢出表两部分,凡是和基本表发生冲突的元素,一律填入溢出表。建立一个公共溢出区域,就是把冲突的都放在另一个地方,不在表里面。

标签:Hash,key,碰撞,37,地址,冲突,哈希,散列,四种
来源: https://www.cnblogs.com/beatleC/p/16060170.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有