码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • DSA之查找(3):哈希表的查找


    文章目录

    • 1 哈希表的基本概念
      • 1.1 两个例子
      • 1.2 如何查找
      • 1.3 若干术语
    • 2 哈希函数的构造方法
      • 2.1 直接定址法
      • 2.2 除留余数法
    • 3 处理冲突的方法
      • 3.1 开放地址法
        • 3.1.1 线性探测法
        • 3.1.2 二次探测法
        • 3.1.3 伪随机探测法
      • 3.2 链地址法(拉链法)
        • 3.2.1 创建步骤
        • 3.2.2 链地址法的特点
    • 4 哈希表的查找
      • 4.1 线性探测法举例
      • 4.2 链地址法举例
      • 4.3 哈希表的查找性能分析
    • 5 结论

    1 哈希表的基本概念

    在这里插入图片描述

    • 基本思想:记录的存储位置与关键字之间存在对应关系
    • 对应关系:使用 h a s h hash hash函数进行对应
    • h a s h hash hash函数: L o c ( i ) = H ( k e y i ) Loc(i) = H(keyi) Loc(i)=H(keyi),常见的“键值表示法”

    1.1 两个例子

    键值存储举例。
    在这里插入图片描述
    在这里插入图片描述

    1.2 如何查找

    在这里插入图片描述
    时间复杂度仅为 O ( 1 ) O(1) O(1),但是空间空着非常多,效率较低。

    1.3 若干术语

    • 散列方法(杂凑法):选取某个函数,依该函数按关键字计算元素的存储位置,并按此存放;
      查找时,由同一个函数对给定值 k k k计算地址,将 k k k与地址单元中元素关键码进行对比,确定查找是否成功。

    • 散列函数(杂凑函数):散列方法中使用的转换函数, H ( k e y ) = k H(key) = k H(key)=k。

    • 散列表(哈希表,杂凑表):按上述思想构造的表。

    • 冲突:不同的关键码映射到同一个散列地址,键不等,地址相等。

    • 同义词:具有相同函数值的多个关键字
      在这里插入图片描述

    2 哈希函数的构造方法

    在这里插入图片描述
    在这里插入图片描述
    构造散列函数考虑的因素

    1. 执行速度(即计算散列函数所需时间);
    2. 关键字的长度;
    3. 散列表的大小;
    4. 关键字的分布情况;
    5. 查找频率。

    在这里插入图片描述

    2.1 直接定址法

    在这里插入图片描述
    不会产生冲突。

    2.2 除留余数法

    在这里插入图片描述
    按照余数来进行存储。

    3 处理冲突的方法

    在这里插入图片描述

    3.1 开放地址法

    在除留余数法的基础上加上了一个增量序列。
    在这里插入图片描述

    3.1.1 线性探测法

    在这里插入图片描述
    在这里插入图片描述
    di是从1开始进行递增的,1不行就加2加2不行就加3,以此类推。

    3.1.2 二次探测法

    在这里插入图片描述

    3.1.3 伪随机探测法

    增量变为伪随机数。在这里插入图片描述

    3.2 链地址法(拉链法)

    基本思想:相同散列地址的记录链成一单链表m个散列地址就设m个单链表,然后用一个数组将m个单链表的表头指针存储起来,形成一个动态的结构。
    在这里插入图片描述
    这四个求余数后,相同,所以把这些链接在同一个单链表上。在这里插入图片描述
    在这里插入图片描述

    3.2.1 创建步骤

    在这里插入图片描述

    3.2.2 链地址法的特点

    • 非同义词不会冲突,无“聚集”现象
    • 链表上结点空间动态申请,更适合于表安不确定的情况

    4 哈希表的查找

    在这里插入图片描述

    4.1 线性探测法举例

    在这里插入图片描述

    4.2 链地址法举例

    在这里插入图片描述

    在这里插入图片描述

    4.3 哈希表的查找性能分析

    在这里插入图片描述
    在这里插入图片描述

    5 结论

    在这里插入图片描述

  • 相关阅读:
    c#中上传超过30mb的文件,接口一直报404,小于30mb的却可以上传成功
    【算法题】2909. 元素和最小的山形三元组 II
    【MySQL系列】MySQL表的增删改查(基础)
    LFS(Linux From Scratch)构建过程全记录(七):进入Chroot并构建临时工具
    嵌入式数据库开发编程(四)——DDL、DML
    CentOS系统环境搭建(十九)——CentOS7安装chat GPT
    尝试使用jmeter-maven-plugin
    轻松实现PDF文件的在线浏览
    Windows系统ping命令的c++实现
    力扣538 补9.18
  • 原文地址:https://blog.csdn.net/weixin_44673253/article/details/126234473
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号