哈希表的构造方法

Posted gw977

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了哈希表的构造方法相关的知识,希望对你有一定的参考价值。

1. 常用哈希表的构造方法

  (1)除余

  (2)随机

  (3)平方后取中间某几位

  (4)折叠

  (5)H(key)= a*key + b

  (6)数字分析:若10位key的特定某几位中,数字大小分布均衡,就取那几位的

2. 处理冲突

  (1)开放定址

  (2)公共溢出

  (3)多个哈希表

  (4)链表

3. 性能分析

 三个因素:

  哈希函数,处理冲突的方法,哈希表的装填因子。

  装填因子 a 的定义如下:  a  = 哈希表中元素的个数 / 哈希表的长度           

                                            a 可描述哈希表的装满程度。a 越小,发生冲突的可能性越小; a 越大 ,发生冲突的可能性越大。

  技术图片

 

技术图片

 

以上是关于哈希表的构造方法的主要内容,如果未能解决你的问题,请参考以下文章

数据结构哈希表

hash表原理

这是为成员函数的 C++ 模板部分特化构造类的好方法吗?

笔记整理--算法

数据结构——哈希表的构造和查找

哈希表的简单操作