哈希表的建立是为了提高查找的速度。一般的线性表记录在结构中的位置是随机的,当要查找某个数是需要逐渐一比较记录与目标关键字的值看是否相等,这样查找的效率会很低;而哈希表通过哈希函数建立一种物理位置与关键字一一对应的关系,当要查找关键字时,只需要计算哈希函数便可得到该关键字的地址查找到所需关键字。
关键字: 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。
二、再哈希法:当冲突发生时,选择其他的函数再次计算地址,直至找到空地址为止
三、链地址:为每个同类关键字建立一个链表,如下:
四、公共溢出区:为冲突关键字建立公共存放区域,当有冲突关键字产生时直接插入公共溢出区中。