初识哈希表

1.引入

在这里插入图片描述

2.哈希思想

在这里插入图片描述
在这里插入图片描述
哈希既是一种查找技术,也是一种存储技术。
哈希只是通过记录的关键字定位该记录,哈希表没有表达记录之间的逻辑关系。所以,哈希主要是面向查找的存储结构

  • 不适用于:
    ⁻ 范围查找
    ⁻ 多个记录有相同关键字

【冲突】
在这里插入图片描述

3.哈希技术的三个关键问题

  • 哈希表容量的设计
    保证n个记录能够存进去,又使得存储空间尽可能少

  • 哈希函数的设计
    如何设计一个运算过程简单、运算结果均匀的哈希函数

  • 冲突的处理方法
    如何采取合适的处理冲突方法来解决冲突

3.1 哈希表容量的设计

在这里插入图片描述

3.2 哈希技术关键之二:哈希函数

在这里插入图片描述

哈希函数构造方法

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

哈希函数示例:线性函数

在这里插入图片描述

哈希函数示例:除留余数法

在这里插入图片描述

3.3 哈希技术关键之三:解决冲突策略

在这里插入图片描述

开放定址法

在这里插入图片描述

开放定址法——线性探测法(Linear Probing)

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

ASL的成功与不成功计算法
在这里插入图片描述

在这里插入图片描述

用线性探测法创建哈希表的查找算法

在这里插入图片描述

用线性探测法创建哈希表的插入算法

在这里插入图片描述

开放定址法——平方探测法(Quadratic Probing)

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

在平方探测法构造的哈希表中进行查找的算法

在这里插入图片描述

在二次探测法构造的哈希表中进行插入操作的算法

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

拉链法(链地址法)

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

在拉链法构造的哈希表中查找并插入的算法

在这里插入图片描述

解决方法的比较

在这里插入图片描述

4. 哈希查找的性能分析

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

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

杰深入学习计算机

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值