19-数据结构-查找-散列查找

目录

一、散列查找结构思路图

二、哈希函数

三、解决冲突

1.开放地址法

1.1.线性探测法(线性探测再散列法)

1.2.平方探测法(二次探测再散列)

1.3.再散列法(双散列法)

2.拉链法

2.1简介

四、散列查找性能

4.1.散列查找

4.2.装填因子

4.2.1关于装填因子的平均昌曌长度的计算。

4.3.查找成功的平均查找长度。

4.3.1.开放地址法-查找成功

4.3.2.拉链法-查找成功

4.4.查找失败的平均查找长度

4.4.1.开放地址法-查找失败

4.4.1.拉链法-查找失败


一、散列查找结构思路图

二、哈希函数

        简介:把查找表中的关键字映射成该关键字对应的地址的函数,记为Hash(key)=Addr.即通过哈希函数的公式计算,得到关键字地址。其中哈希函数分为五种,选择一种即可。具体看一中的思路图。

        这里面主要说明除留余数法,这里考试考察,公式为Hash(key)=key%p,p为数组中最大素数,key为关键字。如图,

通过哈希函数的除留余数法,计算关键字在数组中的坐标,从而填在相应的位置下。

三、解决冲突

1.开放地址法

        简介:即数组中位置,即向相同位置的关键字开放,也对不同的开放。

1.1.线性探测法(线性探测再散列法)

Hash(key)=(key+di)%p.其中di=1,2,3,4,5,6.......

直接看图-强连通例题

        当关键字37时,通过除留余数法,发现冲突,此时,需要用到线性探测法即,H1=(H(37)+1)%12,这里H(37)为除留余数法初始坐标。从而算出新的地址,如果此时不冲突则填进去,否则再进行计算H2=(H(37)+2)%12,直到不冲突位置。此外,如果在散列表中,删除关键字,只能逻辑删除,物理删除的话,会造成后续关键字映射紊乱。

此外,若有k个关键字,弄成散列表,则需要k*(k+1)/2次对比。第一个1次。第二个2次。以此类推,等差数列。

1.2.平方探测法(二次探测再散列)

相比于线性探测而言,它的di不同,di为(1,-1,2,-2,4,-4)

例题:

45先是通过除留余数法计算,发现6,冲突了,从而进行第一次冲突计算,此时di=1,带进公式计算即可,如果还冲突,则di更新为-1,注意H(45)=6这个初始位置不变,跟着di带进公式即可。

1.3.再散列法(双散列法)

        即先通过除留余数法计算,如果地址冲突了,再通过第二个函数式子,进行位置计算,一般不同题中给的再散列函数不一样,不过按照所给的条件,带入计算即可。

例题:

简单来说,就是分两步,先是通过正常的除留余数法进行计算地址,如果,发生冲突,则通过题干中给的第二个函数,进行新地址的计算。

2.拉链法

2.1简介

        拉链法,为了避免开放地址法中的聚集现象,以及插入删除不方便等情况应运而生。

直接看图吧,相比于开放定址法,这里处理冲突的方法,则是,通过除留余数法,所求的相同的地址,都放在一个单链表中,那么此时该地址的链,为同义词所在的链。

四、散列查找性能

4.1.散列查找

即我们构造完散列表了,然后通过关键则,获取在表中的位置。先通过哈希函数hash(key)=key%p=addr,获取初始位置,如果此时L(addr)==key则返回addr即可,否则addr+1,往后查找,验证l(addr+1)==key?直到符合条件,返回此时的位置即可。

4.2.装填因子

一般记为a,表示表中装满程度,a=表中记录关键字数/表长度。

a越大,说明此时表中填充的越多,下次再加入关键字冲突的可能性就越大。

4.2.1关于装填因子的平均昌曌长度的计算。

4.3.查找成功的平均查找长度。

4.3.1.开放地址法-查找成功

        即每个关键字比较次数总和/关键字总数。比较次数即冲突数+1.在构造散列表的时候,顺便就计算了,

4.3.2.拉链法-查找成功

        直接看图好理解。

4.4.查找失败的平均查找长度

4.4.1.开放地址法-查找失败

        这里先需要直到映射地址的范围,即除留余数法中的key%p的p,这个为范围。然后从范围第一个位置,查找,直到后面遇到空白才听,空白也算一次查找失败,这是一个位置的查找失败,然后从左到右,依次计算,直到映射地址计算完毕,

        注意如果散列表中,删除关键字,则为逻辑删除,但是在进行查找长度计算时,它仍物理存在,计算的时候要算上。

删除关键字后的查找失败的平均查找长度

4.4.1.拉链法-查找失败

即,散列表中空白处算1次查找失败,有链表的地方,为链表长度+1,因为后面的空指针,也算一次比较。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/240105.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

飞天使-linux操作的一些技巧与知识点3-http的工作原理

文章目录 http工作原理nginx的正向代理和反向代理的区别一个小技巧dig 命令巧用 http工作原理 http1.0 协议 使用的是短连接,建立一次tcp连接,发起一次http的请求,结束,tcp断开 http1.1 协议使用的是长连接,建立一次tc…

【ARM Trace32(劳特巴赫) 使用介绍 13 -- Trace32 断点 Break 命令篇】

文章目录 1. Break.Set1.1 TRACE32 Break1.1.1 Break命令控制CPU的暂停1.2 Break.Set 设置断点1.2.1 Trace32 程序断点1.2.2 读写断点1.2.2.1 变量被改写为特定值触发halt1.2.2.2 设定非值触发halt1.2.2.4 变量被特定函数改写触发halt1.2.3 使用C/C++语法设置断点条件1.2.4 使用…

深入理解 SVG:开启向量图形的大门(下)

🤍 前端开发工程师(主业)、技术博主(副业)、已过CET6 🍨 阿珊和她的猫_CSDN个人主页 🕠 牛客高级专题作者、在牛客打造高质量专栏《前端面试必备》 🍚 蓝桥云课签约作者、已在蓝桥云…

AutoCAD输入命令突然显示 未知命令。按 F1查看帮助。

CAD一直好的,突然坏了,不能输入命令了,其他功能正常。输入命令显示“未知命令XXX,按 F1 查看帮助。” 网上说的什么病毒,卸载重装等无效。结果发现输入的字符是全角的,不是半角的,就输入法的问…

C++面试宝典第5题:判断素数

题目 判断一个正整数是否为素数有哪几种方法,每种方法的时间复杂度怎么样。 解析 素数又称质数,是指在大于1的自然数中,除了1和它本身以外,不再有其他因数的自然数。素数只有1和它本身两个正因数,最小的素数是2&#x…

【Vue】router.push用法实现路由跳转

目录 router.push用法 在Login.vue中 在Register.vue中 ​ 上一篇:登录与注册界面的制作 https://blog.csdn.net/m0_67930426/article/details/134895214?spm1001.2014.3001.5502 制作了登录与注册界面,并介绍了相关表单元素即属性的用法 在登录页面…

第三十四周:文献阅读+LSTM学习

目录 摘要 Abstract 文献阅读:综合EMD-LSTM模型在城市排水管网水质预测中的应用 现有问题 提出方法 EMD-LSTM综合模型 研究框架 结论 Long Short-term Memory(长短期记忆) 1. LSTM的结构 2. Multiple-layer LSTM 3.3 LSTM Example 3. GRU LSTM实现PM2…

【K8S 系列】认识k8s、k8s架构

一、什么是k8s? Kubernetes 简称 k8s,是支持云原生部署的一个平台,k8s 本质上就是用来简化微服务的开发和部署的,用于自动化部署、扩展和管理容器化应用的开源容器编排技术。对于传统的docker其实也提供了容器编排的技术docker-compose&…

Rust语言GUI库之gtk安装

文章目录 工具链安装管理软件vcpkgvcpkg介绍安装vcpkg 安装gtk遇到的问题Rust其他依赖package-confg 工具链安装管理软件vcpkg vcpkg介绍 在使用C/C编写项目时, 引用第三方库是很麻烦的事, 需要手动下载源码然后编译最后再添加到项目里,配置头文件、lib、dll&…

PyTorch: 基于【MobileNet V2】处理MNIST数据集的图像分类任务【准确率99%+】

目录 引言1. 安装PyTorch2. 下载并加载MNIST数据集3. 搭建基于MobileNet V2的图像分类模型运行结果(重点看网络开头和结束位置即可) 4. 设置超参数、损失函数、优化器5. 训练模型6. 测试模型运行结果 完整代码结束语 引言 在深度学习和计算机视觉的世界…

Windows使用selenium操作浏览器爬虫

以前的大部分程序都是操作Chrome,很少有操作Edge,现在以Edge为例。 Selenium本身是无法直接控制浏览器的,不同的浏览器需要不同的驱动程序,Google Chrome需要安装ChromeDriver、Edge需要安装Microsoft Edge WebDriver&#xff0c…

【PostgreSQL】从零开始:(一)初识PostgreSQL

从零开始:(一)初识PostgreSQL PostgreSQL数据库介绍为什么使用 PostgreSQL?那么多最终用户,云厂商为什么要贡献核心代码?基于PostgreSQL底层开发的好处:为什么要学习PostgreSQL?截止本文发布之日&#xff0…

Web安全之XXE漏洞原理及实践学习

一、原理: XXE漏洞全称即XML外部实体注入漏洞。 攻击者强制XML解析器去访问攻击者指定的资源内容(可能是系统上本地文件亦或是远程系统上的文件),导致可加载恶意外部文件,利用file协议造成文件读取、命令执行、内网端口扫描、攻击内网网站等…

【图论-匈牙利算法】Hungary Algorithm完整代码(一) 之 matlab实现

学习参考链接 博客 分配问题与匈牙利算法 带你入门多目标跟踪(三)匈牙利算法&KM算法 视频 运筹学 | 例题详解指派问题 前言 图论-匈牙利算法原理参见上述参考连接中的博客与BiliBili博主的学习视屏,讲的很好很透彻。强烈建议看完&#…

自定义日志打印功能--C++

一、介绍 日志是计算机程序中用于记录运行时事件和状态的重要工具。通过记录关键信息和错误情况,日志可以帮助程序开发人员和维护人员追踪程序的执行过程,排查问题和改进性能。 在软件开发中,日志通常记录如下类型的信息: 事件信…

关于碰撞试验

主要参数: 冲击与碰撞试验的主要参数及调整方法 - 百度文库 碰撞试验的技术指标包括:峰值加速度、脉冲持续时间、速度变化量(半正弦波)、每方向碰撞次数。 加速度:冲击的强度,单位为g;一般为3…

Zygote 进程启动过程

首语 在Android系统中,DVM(Dalvik虚拟机)和ART、应用程序进程以及运行系统的关键服务的SystemServer进程都是由Zygote进程创建的,也可以将其称之为孵化器,它通过fork(复制进程)的形式来创建应用程序进程和SystemServer进程。 Zygote进程是在…

记录一次chatGPT人机协同实战辅助科研——根据词库自动进行情感分析

有一个Excel中的一列,读取文本判断文本包含积极情感词.txt和消极情感词.txt的个数,分别生成两列统计数据 请将 ‘your_file.xlsx’ 替换为你的Excel文件名,Your Text Column’替换为包含文本的列名。 这个程序首先读取了积极和消极情感词&…

(第68天)DBCA 克隆 PDB

介绍 在前面课程我们讲过使用 DBCA 创建数据库以及搭建 DataGuard 等功能,在多租户这章节,要讲下如何使用 DBCA 克隆 PDB。 18C 开始支持使用 DBCA 在本地 CDB 中克隆 PDB19C 升级支持使用 DBCA 克隆 PDB 到远端 CDB 中19C 升级支持使用 DBCA 重定向迁移 PDB 到远端 CDB 中本…

2023/12/12作业

思维导图 作业: 成果图 代码 #include "widget.h" #include "ui_widget.h" Widget::Widget(QWidget *parent) : QWidget(parent) , ui(new Ui::Widget) { speechernew QTextToSpeech(this); ui->setupUi(this); //一直获取当前时间 idst…