- 1、本文档共48页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
散列函数为.ppt
散列表(Hash Table); ;采用的散列函数是
hash(x) = x % 73 + 13420
则有 hash(12361) = hash(07250) = hash(03309) = hash(30976) = 13444。
就是说,对不同的关键码,通过散列函数的计算,得到了同一散列地址。称这些产生冲突的散列地址相同的不同关键码为同义词。
由于关键码集合比地址集合大得多, 冲突很难避免。所以对于散列方法, 需要讨论以下两个问题:;对于给定的一个关键码集合,选择一个计算简单且地址分布比较均匀的散列函数,避免或尽量减少冲突;
拟订解决冲突的方案。
构造散列函数时的几点要求:
散列函数应是简单的,能在较短的时间内 计算出结果。
散列函数的定义域必须包括需要存储的全部关键码,如果散列表允许有 m 个地址; 时,其值域必须在 0 到 m-1 之间。
散列函数计算出来的地址应能均匀分布在整个地址空间中: 若 key 是从关键码集合中随机抽取的一个关键码, 散列函数应能以同等概率取 0 到 m-1 中的每一个值。
直接定址法
此类函数取关键码的某个线性函数值作为散列地址:
Hash(key) = a * key + b {a, b为常数}
这类散列函数是一对一的映射,一般不会产生冲突。但它要求散列地址空间的大小与关; 键码集合的大小相同。
示例:有一组关键码如下:{ 942148, 941269, 940527, 941630, 941805, 941558, 942047, 940001 }。散列函数为
Hash(key) = key - 940000
Hash (942148) = 2148 Hash (941269) = 1269
Hash (940527) = 527 Hash (941630) = 1630
Hash (941805) = 1805 Hash (941558) = 1558
Hash (942047) = 2047 Hash (940001) = 1
可以按计算出的地址存放记录。; ; ;若散列表地址范围有 3 位数字, 取各关键码的 ④⑤⑥ 位做为记录的散列地址。
数字分析法仅适用于事先明确知道表中所有关键码每一位数值的分布情况,它完全依赖于关键码集合。如果换一个关键码集合,选择哪几位要重新决定。
除留余数法
设散列表中允许地址数为m,取一个不大于 m,但最接近于或等于 m 的质数 p 作为除数,用以下函数把关键码转换成散列地址:
hash (key) = key % p, p ? m; 其中,“%”是整数除法取余的运算,要求 p 是不接近 2 的幂的质数。
示例: 有一个关键码 key = 962148,散列表大小 m = 25,即 HT[25]。取质数 p = 23。散列函数 hash(key) = key % p。则散列地址为
hash(962148) = 962148 % 23 = 12。
可按计算出的地址存放记录。注意, 使用散列函数计算出的地址范围是 0 到 22,而 23、24 这几个地址实际上不能用散列函数计算出来,只能在处理冲突时达到这些地址。;平方取中法
它首先计算构成关键码的标识符的内码的平方, 然后按照散列表的大小取中间的若干位作为散列地址。
设标识符可以用一个计算机字长的内码表示。因为内码平方数的中间几位一般是由标识符所有字符决定, 所以对不同的标识符计算出的散列地址大多不相同。
在平方取中法中, 一般取散列地址为 2 的某次幂。例如, 若散列地址总数取为 m = 2r,则对内码的平方数取中间的 r 位。; ; 折叠法
此方法把关键码自左到右分成位数相等的几部分, 每一部分的位数应与散列表地址位数相同, 只有最后一部分的位数可以短一些。
把这些部分的数据叠加起来, 就可以得到具有该关键码的记录的散列地址。
有两种叠加方法:
移位法:把各部分最后一位对齐相加;
分界法:各部分不折断,沿各部分的分界来回折叠, 然后对齐相加。;示例: 设给定的关键码为 key = 23938587841, 若存储空间限定 3 位, 则划分结果为每段 3 位。 上述关键码可划分为 4 段:
239 385 878 41
把超出地址位数的最高位删去, 仅保留最低的3 位,做为可用的散列地址。;一般当关键码的位数很多,而且关键码每一位上数字的分布大致比较均匀时,可用这种方法得到散列地址。
假设地址空间为HT[
您可能关注的文档
- 手机真伪鉴别提示卡-海信手机.doc
- 投标工具说明书.doc
- 河南省建筑业企业一套表.doc
- 投标报价明细表-卫辉市公共资源交易管理中心.doc
- 招标文件校验工具帮助手册-一联易招交易平台.doc
- 法庭觀察記錄表.doc
- 法意瑞+希腊15天.doc
- 拟建加油站区域现状图制作方法.doc
- 拨号界面—选项.ppt
- 拷机监控界面【测试描述】错误提示对照表.doc
- 第十一章 电流和电路专题特训二 实物图与电路图的互画 教学设计 2024-2025学年鲁科版物理九年级上册.docx
- 人教版七年级上册信息技术6.3加工音频素材 教学设计.docx
- 5.1自然地理环境的整体性 说课教案 (1).docx
- 4.1 夯实法治基础 教学设计-2023-2024学年统编版九年级道德与法治上册.docx
- 3.1 光的色彩 颜色 电子教案 2023-2024学年苏科版为了八年级上学期.docx
- 小学体育与健康 四年级下册健康教育 教案.docx
- 2024-2025学年初中数学九年级下册北京课改版(2024)教学设计合集.docx
- 2024-2025学年初中科学七年级下册浙教版(2024)教学设计合集.docx
- 2024-2025学年小学信息技术(信息科技)六年级下册浙摄影版(2013)教学设计合集.docx
- 2024-2025学年小学美术二年级下册人美版(常锐伦、欧京海)教学设计合集.docx
文档评论(0)