- 1、本文档共42页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第十章 散列结构;散列
散列函数
开地址散列向量
桶散列;散列 (Hashing);静态散列方法; ;冲突示例:有一组表项,其关键码分别是
12361, 07251, 03309, 30976
采用的散列函数是
hash(x) = x % 73 + 13420
则有:hash(12361) = hash(07250) = hash(03309) = hash(30976) = 13444。就是说, 对不同的关键码, 通过散列函数的计算, 得到了同一散列地址。我们称这些产生冲突的散列地址相同的不同关键码为同义词。;由于关键码集合比地址集合大得多, 冲突很难避免。所以对于散列方法, 需要讨论以下两个问题:
对于给定的一个关键码集合, 选择一个计算简单且地址分布比较均匀的散列函数;
避免或尽量减少冲突;;构造散列函数时的几点要求:
散列函数应是简单的,能在较短的时间内
计算出结果。
散列函数的定义域必须包括需要存储的全
部关键码, 如果散列表允许有 m 个地址时,
其值域必须在 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
可以按计算出的地址存放记录。; ; 9 4 2 1 4 8
9 4 1 2 6 9
9 4 0 5 2 7
9 4 1 6 3 0
9 4 1 8 0 5
9 4 1 5 5 8
9 4 2 0 4 7
9 4 0 0 0 1
① ② ③ ④ ⑤ ⑥ ;数字分析法仅适用于事先明确知道表中所有关键码每一位数值的分布情况,它完全
如果换一个关键码集合,选择哪几位要重新决定。;③除留余数法
设散列表中允许地址数为 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的某次幂。; ; 折叠法
此方法把关键码自左到右分成位数相等的几部分, 每一部分的位数应与散列表地址位数相同, 只有最后一部分的位数可以短一些。
把这些部分的数据叠加起来, 舍去进位,就可以得到具有该关键码的记录的散列地址。
有两种叠加方法:
移位法 — 把各部分的最后一位对
您可能关注的文档
- chapter5弹性力学解答.ppt
- NO7信令系统基础解答.ppt
- 2014年秋八年级政治上册第二课《家庭剧场》(第2课时)剧场内外课件人民版解答.ppt
- 2014年教学工作计划和目标解答.ppt
- 雅高矿业ERP项目_To-Be_计划模块_目标流程及解决方案_V04解决方案.doc
- Chapter5操作系统解答.ppt
- 雅阁营销环境解决方案.doc
- 雅思听力词汇解决方案.doc
- 2014年供应商发展科产品知识解答.ppt
- chapter5_-虚拟存储器解答.ppt
- 会员和忠诚度计划模板.pptx
- 民用桌面3d打印机项目创业计划书_20250204_195348.docx
- 服装企业的品牌商业计划书【精选】.docx
- 月子会所商业计划书_20250204_210026.docx
- 智能家居安全设备商业计划书.docx
- 烧结机烟气脱硫脱硝一体化项目可行性研究报告方案(可用于发改委立项及_20250204_192035.docx
- 2025年浙江余姚市众泰机动车辆检测有限公司招聘笔试参考题库附带答案详解.pdf
- 2025年河南许昌建安保税区开发建设有限公司招聘笔试参考题库附带答案详解.pdf
- 2025年陕西西安佰仕达人才服务有限责任公司招聘笔试参考题库附带答案详解.pdf
- 新型铁沟浇注料项目融资商业计划书(包括可行性研究报告+资金方案规划+.docx
最近下载
- 2025年二建《建设工程施工管理》精选考点汇总.pdf VIP
- 出口扫描系列·变局篇:找寻出口商品的“稳定之星”.pdf VIP
- 开关站10kV开关柜检修试验标准化作业指导书1.pdf
- 2023年江西机电职业技术学院高职单招语文/数学/英语考试题库答案详解.docx
- 人教版高中数学必修五1.1.1《正弦定理》教学课件1 (共13张PPT).ppt VIP
- GB_T 15114-2023 铝合金压铸件.docx
- 2024年度组织生活会支部班子对照检查材料.doc VIP
- 5.1+人要自强+课件-+2024-2025学年统编版道德与法治七年级下册.pptx VIP
- 弱电系统维保方案(三篇).pdf VIP
- 义务教育劳动课程标准(2022年版).pdf
文档评论(0)