哈希表是什么课件.ppt
- 【下载声明】
1. 本站全部试题类文档,若标题没写含答案,则无答案;标题注明含答案的文档,主观题也可能无答案。请谨慎下单,一旦售出,不予退换。
2. 本站全部PPT文档均不含视频和音频,PPT中出现的音频或视频标识(或文字)仅表示流程,实际无音频或视频文件。请谨慎下单,一旦售出,不予退换。
3. 本页资料《哈希表是什么课件.ppt》由用户(三亚风情)主动上传,其收益全归该用户。163文库仅提供信息存储空间,仅对该用户上传内容的表现方式做保护处理,对上传内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(点击联系客服),我们立即给予删除!
4. 请根据预览情况,自愿下载本文。本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
5. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007及以上版本和PDF阅读器,压缩文件请下载最新的WinRAR软件解压。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 哈希表 是什么 课件
- 资源描述:
-
1、 一、一、哈希表是什么?哈希表是什么?二、哈希函数的构造方法哈希函数的构造方法 三、处理冲突的方法处理冲突的方法 四、哈希表的查找哈希表的查找9.3 哈哈 希希 表表 以上两节讨论的表示查找表的各种结构结构的共同特点特点:记录在表中的位置位置和它的关关键字键字之间不存在不存在一个确定的关系,一、哈希表是什么?哈希表是什么? 查找的过程查找的过程为给定值给定值依次和关键字集合中各个关键字关键字进行比较比较, 查找的效率查找的效率取决于和给定值进行比较进行比较的关键字个数个数。 只有一个办法:预先知道所查关键字在表中的位置, 对于频繁使用的查找表,希望 ASL = 0。 即要求:记录在表中位置和其
2、关键字之间存在一种确定的关系。若以下标为以下标为000 999 的顺序表的顺序表表示之。例如:为每年招收的 1000 名新生建立一张查找表,其关键字为学号,其值的范围为 xx000 xx999 (前两位为年份)。则查找过程可以简单进行:取给定值(学号)的后三位,不需要经过比较不需要经过比较便可直接从顺序表中找到待查关键字。因此在一般情况下,需在关键字与记录在表中的存储位置之间建立一个函数关系,以 f(key) 作为关键字为 key 的记录在表中的位置,通常称这个函数 f(key) 为哈希函数。Zhao, Qian, Sun, Li, Wu, Chen, Han, Ye, Dei 例如:对于如下
3、 9 个关键字设设 哈希函数哈希函数 f(key) = (Ord(第一个字母第一个字母) -Ord(A)+1)/2 0 1 2 3 4 5 6 7 8 9 1 0 1 1 1 2 1 3ChenZhaoQianSunLiWuHanYeDei问题问题: 若添加关键字 Zhou , 怎么办?怎么办?能否找到能否找到另一个哈希函数?1) 哈希函数是一个映象映象,即: 将关键字的集合映射到某个地址集合上,将关键字的集合映射到某个地址集合上, 它的设置很灵活灵活,只要这个地址集地址集合的 大小不超出允许范围不超出允许范围即可;从这个例子可见:从这个例子可见:2) 由于哈希函数是一个压缩映象压缩映象,因此
4、,在一般情况下,很容易产生“冲突冲突”现象,即: key1 key2,而 f(key1) = f(key2)。3) 很难很难找到一个不产生冲突的哈希函数。一般情况下,只能选择恰当的哈希函数,使冲突尽可能少地产生。 因此,在构造这种特殊的“查找表” 时,除了需要选择一个“好”(尽可能少产生冲突)的哈希函数之外;还需要找到一种“处理冲突” 的方法。哈希表的定义: 根据设定的哈希函数哈希函数 H(key) 和所选中的处处理冲突的方法理冲突的方法,将一组关键字映象到映象到一个有限的、地址连续的地址集 (区间) 上,并以关键字在地址集中的“象”作为相应记录在表中的存储位置存储位置,如此构造所得的查找表称
5、之为“哈希表哈希表”或“散列表散列表”。这一映象过程称为“哈希造表哈希造表”或“散列散列”。所得存储地址称为“哈希地址哈希地址”或“散列地址散列地址”。二、构造哈希函数的方法构造哈希函数的方法 对数字数字的关键字可有下列构造方法: 若是非数字关键字非数字关键字,则需先需先对其进行进行数字化处理数字化处理。1. 直接定址法直接定址法3. 平方取中法平方取中法5. 除留余数法除留余数法4. 折叠法折叠法6. 随机数法随机数法2. 数字分析法数字分析法哈希函数为关键字的线性函数 H(key) = key 或者 H(key) = a key + b1. 直接定址法直接定址法此法仅适合于:此法仅适合于:
展开阅读全文