JS 数据结构和算法(七)哈希表

本文深入探讨了哈希表的特点,包括其高效插入和删除操作。解释了哈希函数和哈希化过程,强调了均匀分布的重要性。还讨论了哈希表的封装,包括插入、删除、获取元素等操作,并提及当负载因子超过0.75时进行扩容的策略。
摘要由CSDN通过智能技术生成

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) {
   
        <
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值