解决哈希冲突的方法

本文介绍了哈希冲突及其解决方法,包括开放定址法、再哈希法、链地址法,并详细阐述了各种方法的优缺点。开放定址法可能导致数据堆积,删除操作复杂;再哈希法减少了冲突,但计算时间增加;链地址法实现简单,但占用额外空间;此外还提到了建立公共溢出区的方法。
摘要由CSDN通过智能技术生成

一、哈希冲突

  • 哈希函数是一个映像,因此哈希函数的设定很灵活,只要使得任何关键字由此所得的哈希函数值都落在表长允许范围之内即可。
  • 对不同的关键字可能得到同一哈希地址,即key1!=key2,而f(key1)=f(key2),这种现象称冲突
  • 具有相同函数值的关键字对该哈希函数来说称作同义词

二、解决方法

1、开放定址法

  • 开放定址法有个非常关键的特征,就是所有输入的元素全部存放在哈希表里
  • 它的实现是在插入一个元素的时候,先通过哈希函数进行判断,若是发生哈希冲突,就以当前地址为基准,根据再寻址的方法(探查序列),去寻找下一个地址,若发生冲突再去寻找,直至找到一个为空的地址为止。所以这种方法又称为再散列法

1.1、线性探测再散列

以当前冲突位置为起点,步长为1循环查找,直到找到一个空的位置,如果循环完了都占不到位置,就说明容器已经满了。

1.2、二次探测再散列

以当前冲突位置为起点

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值