




已阅读5页,还剩15页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
9.1 概述,9.1.1 查找表,9.1.2 相关术语,9.1.3 类型说明,9.2 静态查找表,9.2.1 概述,9.2.2 顺序表的查找,9.2.3 有序表的查找,9.2.4 索引顺序表的查找,9.3 动态查找表,9.3.1 概述,9.3.2 二叉排序树和平衡二叉树,9.3.3 B-树和B+树,9.4 哈希表,9.4.1 定义,9.4.2 哈希函数的构造,9.4.3 处理冲突的方法,9.4.4 哈希表的查找及其分析,第九章查找,三、处理冲突的方法,假设哈希表的地址集为0-(n-1),冲突是指由关键字得到的哈希地址为j的位置上已存有记录,则“处理冲突”就是为该关键字的记录找到另一个“空”的哈希地址。,1. 开放定址法,2. 链地址法,在处理冲突的过程中可能得到一个地址序列Hi。即在处理哈希地址的冲突时,若得到一个哈希地址Hi仍然发生冲突,则再求下一个地址H2,若H2仍冲突,再求H3。依次类推,直到Hk不发生冲突为止。,为产生冲突的地址 H(key) 求得一个地址序列: H0, H1, H2, , Hs 1 sm-1其中:H0 = H(key) Hi = ( H(key) + di ) MOD m i=1, 2, , s,1. 开放定址法,对增量 di 有三种取法:,1) 线性探测再散列 di = c i 最简单的情况 c=12) 平方探测再散列(也称为二次探测再散列) di = 12, -12, 22, -22, ,3) 随机探测再散列 di 是一组伪随机数列 或者 di=iH2(key) (又称双散列函数探测),即:产生的 Hi 均不相同,且所产生的 s(m-1)个 Hi 值能覆盖哈希表中所有 地址。则要求:,注意:增量 di 应具有“完备性”, 随机探测时的 m 和 di 没有公因子。, 平方探测时的表长 m 必为形如 4j+3 的素数(如: 7, 11, 19, 23, 等);,例如: 关键字集合 19, 01, 23, 14, 55, 68, 11, 82, 36 ,设定哈希函数 H(key) = key MOD 11 ( 表长=11 ),19,01,23,14,55,68,19,01,23,14,68,若采用线性探测再散列处理冲突,若采用二次探测再散列处理冲突,11,82,36,55,11,82,36,1 1 2 1 3 6 2 5 1,Hi = ( H(key) + di ) MOD m,线性探测再散列 di = c i 最简单的情况 c=1,H2(key) 是另设定的一个哈希函数,它的函数值应和 m 互为素数。,若 m 为素数,则 H2(key) 可以是 1 至 m-1 之间的任意数;,若 m 为 2 的幂次,则 H2(key) 应是 1 至 m-1 之间的任意奇数。,例如,当 m=11时, 可设 H2(key)=(3 key) MOD 10+1,19,01,23,14,55,68,11,82,36,2 1 1 1 2 1 2 1 3,将所有哈希地址相同的记录都链接在同一链表中。,2. 链地址法,ASL=(61+22+3)/9=13/9,例如:同前例的关键字,哈希函数为 H(key)=key MOD 7,查找过程和造表过程一致。假设采用开放定址处理冲突,则查找过程为:,四、哈希表的查找,对于给定值 K, 计算哈希地址 i = H(K),若 ri = NULL 则查找不成功,若 ri.key = K 则查找成功,否则 “求下一地址 Hi” ,直至 rHi = NULL (查找不成功) 或 rHi.key = K (查找成功) 为止。,int hashsize = 997, . ; typedef struct ElemType *elem; int count; / 当前数据元素个数 int sizeindex; / hashsizesizeindex为当前容量 HashTable;#define SUCCESS 1#define UNSUCCESS 0#define DUPLICATE -1,/- 开放定址哈希表的存储结构 -,Status SearchHash (HashTable H, KeyType K, int &p, int &c) / 在开放定址哈希表H中查找关键码为K的记录 / SearchHash,p = Hash(K); / 求得哈希地址,while ( H.elemp.key != NULLKEY / 求得下一探查地址 p,if (EQ(K, H.elemp.key) return SUCCESS; / 查找成功,返回待查数据元素位置 p,else return UNSUCCESS; / 查找不成功,Status InsertHash (HashTable &H, Elemtype e) / InsertHash,c = 0;,if ( HashSearch ( H, e.key, p, c ) = SUCCESS ) return DUPLICATE; / 表中已有与 e 有相同关键字的元素,else H.elemp = e; +H.count; return OK; / 查找不成功时,返回 p为插入位置,else RecreateHashTable(H); / 重建哈希表,if ( c hashsizeH.sizeindex/2 ) / 冲突次数 c 未达到上限,(阀值 c 可调) ,决定哈希表查找的ASL的因素:,哈希表查找的分析:,从查找过程得知,哈希表查找的平均查找长度实际上并不等于零。,1) 选用的哈希函数;2) 选用的处理冲突的方法;3) 哈希表饱和的程度,装载因子 =n/m 值的大小(n记录数,m表的长度),一般情况下,可以认为选用的哈希函数是“均匀”的,则在讨论ASL时,可以不考虑它的因素。,因此,哈希表的ASL是处理冲突方法和装载因子的函数。,例如:前述例子,线性探测处理冲突时, ASL =,双散列探测处理冲突时,ASL =,链地址法处理冲突时, ASL =,22/9,14/9,13/9,线性探测再散列,链地址法,随机探测再散列,可以证明:查找成功时有下列结果:,从以上结果可见,,哈希表的平均查找长度是 的函数,而不是 n 的函数。,这说明,用哈希表构造查找表时,可以选择一个适当的装填因子 ,使得平均查找长度限定在某个范围内。, 这是哈希表所特有的特点。,1. 顺序表和有序表的查找方法及其平均查找长度的
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 【正版授权】 ISO/IEC GUIDE 71:2014 EN Guide for addressing accessibility in standards
- 【正版授权】 IEC 60245-6:1994 EN-D Rubber insulated cables - Rated voltages up to and including 450/750 V - Part 6: Arc welding electrode cables
- 古诗文阅读拓展:初中教材同步教学
- 教育机构教师聘任及教学管理合同
- 六一公司庆祝活动方案
- 六一商铺活动方案
- 六一布置公司活动方案
- 六一晨练活动方案
- 六一民警送礼物活动方案
- 六一活动排桌子活动方案
- 【MOOC】环境资源法学-西南政法大学 中国大学慕课MOOC答案
- 居家护理的形式家庭病床
- 燕罗智能网联汽车产业园建筑方案设计
- 特许经营合作合同
- 人教版九年级物理 14.3能量的转化和守恒(学习、上课课件)
- 江苏省徐州市贾汪区2023-2024学年七年级上学期期中考试数学试卷(含解析)
- 《港口粉尘在线监测系统建设技术规范(征求意见稿)》编制说明
- 品质巡检个人工作计划
- 医院采购委员会管理制度
- 设备管道 防腐保温施工方案
- DZ∕T 0214-2020 矿产地质勘查规范 铜、铅、锌、银、镍、钼(正式版)
评论
0/150
提交评论