哈希表冲突解决

     哈希表的建立是为了提高查找的速度。一般的线性表记录在结构中的位置是随机的,当要查找某个数是需要逐渐一比较记录与目标关键字的值看是否相等,这样查找的效率会很低;而哈希表通过哈希函数建立一种物理位置与关键字一一对应的关系,当要查找关键字时,只需要计算哈希函数便可得到该关键字的地址查找到所需关键字。

  关键字: 1     2     3     4     5     6     7      8 ········

      地址:01   02   03   04  05    06    07    08·······

 哈希函数f(x)=x

     然而在通过哈希函数建立关键字与物理地址的对应关系时,往往不同的关键字会得到相同的地址,即产生冲突。通常情况下提供了三种解决冲突的办法:开放地址法,再哈希法,链地址和公共溢出区。

    散列:45,18,36,26,12,11,10,5

   一、 开放地址法:

    公式:Hi=(H(key)+di) MOD m i=1,2,...,k(k<=m-1)

    H(45)MOD8=5    H(18)MOD8=2    H(36)MOD8=4         H(11)MOD8=3    

    H(5)=5                  H(10)MOD8=2     H(12)MOD8=4

                                  H(26)MOD8=2

    如上,对于不同一个关键字利用哈希函数计算得到了相同的地址,为了解除冲突,可以利用再次求的地址直至找到一个空地   址如18经过三次计算可得到地址6。

 

  二、再哈希法:当冲突发生时,选择其他的函数再次计算地址,直至找到空地址为止

 

  三、链地址:为每个同类关键字建立一个链表,如下:

 

                  

 

   四、公共溢出区:为冲突关键字建立公共存放区域,当有冲突关键字产生时直接插入公共溢出区中。

 

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值