7.哈希表
特点
-
优点
-
插入和删除元素效率高,O(1)时间级
-
速度比树还要快,编码较简单
-
-
缺点
-
无序
-
key不能重复
-
哈希函数
- 哈希化: 将大数字转化成数组范围内下标的过程, 我们就称之为哈希化.
- 哈希函数: 通常我们会将单词转成大数字, 大数字在进行哈希化的代码实现放在一个函数中, 这个函数我们成为哈希函数.
- 哈希表: 最终将数据插入到的这个数组, 我们就称之为是一个哈希表
哈希化效率
装填因子:装填因子 = 总数据项 / 哈希表长度.
链地址法:可能大于1;开放地址法:最大为1
相对来说,链地址法效率是好于开放地址法的.
快速计算:霍纳法则
计算哈希值的时候使用的方式
-
cats = 327³+127²+20*27+17= 60337
-
乘法次数: n+(n-1)+…+1=n(n+1)/2
-
加法次数: n次
霍纳算法:Pn(x)= anxn+a(n-1)x(n-1)+…+a1x+a0
= ((…(((anx +an-1)x+an-2)x+ an-3)…)x+a1)x+a0
-
乘法次数: N次
-
加法次数: N次.
-
如果使用大O表示时间复杂度的话, 我们直接从O(N²)降到了O(N).
均匀分布
使用质数:
- 哈希表的长度.
- N次幂的底数(我们之前使用的是27)
哈希函数实现
function hashFunc(str, max) {
// 1.初始化hashCode的值
var hashCode = 0
// 2.霍纳算法, 来计算hashCode的数值
for (var i = 0; i < str.length; i++) {
hashCode = 37 * hashCode + str.charCodeAt(i)
}
// 3.取模运算
hashCode = hashCode % max
return hashCode
}
哈希表封装
// 创建HashTable构造函数
function HashTable() {
// 定义属性
this.storage = []
this.count = 0
this.limit = 8
// 定义相关方法
// 哈希函数
HashTable.prototype.hashFunc = function(str, max) {
<