散列结构的查找:
散列函数:一 个把查找表中的关键字映射成该关键字对应的地址的函数,记为Hash(key)=Address。
冲突:散列函数可能会把两个或两个以上的关键字映射到同一地址。
散列表:根据关键字直接进行访问的数据结构,对散列表的查找的时间复杂度为O(1)。
散列函数的构造:
要求:
①散列函数的定义域必须包括所有的要储存的关键字,而值域范围依赖于散列表的大小或地址范围。
②散列函数计算出来的地址应该等概率,均匀的分布在整个地址空间,从而减少冲突的发生。
③散列函数应尽可能简单,能够在较短时间内计算出关键字的地址。
方法:
①直接定址法
取关键字的线性函数值作为地址。
H(key)=a*key+b
②除留余数法
取一个不大于散列表长,但接近它的数字p
H(key)=key % p
③数字分析法
r进制数对于r个数来说,已知的关键字序列其中r个数出现的频率不同,
所以应该选择分布较为均匀的若干位作为散列地址。
④平方取中法
取关键字的平方数的中间几位作为散列地址,
适用于关键字的每一位都分布不均匀或都小于散列地址所需的位数
⑤折叠法
将关键字分割成位数相同的几部分,然后取这几部分的叠加和作为散列地址。
适用于关键字位数很多,且每一位关键字数字大小分布均匀。