- 1、本文档共39页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
* 一种改进的方法 ∞ 0 ∞ 0 ∞ 0 ∞ 0 ∞ 0 * 与线性开型寻址散列比较 空间: 线性开型寻址散列 :b(s+2) (数组 empty: 2b) 链表散列 : 2b+2n+ns 当bbs/(s+2) , 链表方法所占用的空间要比开型寻址少. 在实现线性开型寻址散列时采用一种节约空间的方法,二者间的比较结果可能会发生变化。 压缩数组empty 使用一个不可能用到的整数( –1或INT_MAX )作为空桶的关键字。 * 与线性开型寻址散列比较 时间复杂性: 线性开型寻址散列 : 最坏情况: ?(n) 平均性能: Sn ~ ? (1 + 1/(1- α )) Un ~ ? (1+1/(1- α)2) 链表散列 : 最坏情况: O(n) 平均性能: Sn ~ 1+ α/2 Un ~ (1+ α)/2 α =1 Un = α α 1 * 与线性开型寻址散列比较 一次不成功搜索所要搜索的节点数为 : i=1 0 i=0 0 …… i 平均性能Un : 链表的平均长度为: n/b= α Un~ (α + 1)/2 α =1 Un= α ? α 1 * 与线性开型寻址散列比较 假定 :各元素是按升序插入的。 当插入第i 个元素时 0 …… 1次 2次 3次 i次 ki 0 …… (i-1)/b 平均性能Sn : * 与线性开型寻址散列比较 Search ki: (i-1)/b+1 使用链表时的平均性能要优于使用线性开型寻址。 ki 0 …… (i-1)/b * 与跳表比较 跳表和散列均使用了随机过程来提高字典操作的性能 时间复杂性: 最坏情况: 跳表: ?(n+MaxLevel) 链表散列: ?(n) 平均性能: 跳表: O(logn) 链表散列: O(1) 空间 (指针所占用的空间 ): 跳表: 平均: MaxLevel+n/(1-p) 最坏情况: n*MaxLevel+1 链表散列: D+n * 与跳表比较 跳表比散列表更灵活. 在线性时间内按升序输出所有的元素.而采用链表散列时,需要(D+n) 时间去收集n 个元素,并且需要O(nlogn)时间进行排序,之后才能输出 。 查找或删除最大或最小元素,散列可能要花费更多的时间(仅考虑平均复杂性)。 * 练习 1.设有一组关键字:{19,14,23,01,68,20,84,27,55,11,10,79},采用哈希函数: H(key)=key mod 13,采用线性开型寻址方法解决溢出。 要求:在0∽12的散列地址空间中对该关键字序列构造哈希表。搜索元素27,55所花的比较次数各是多少? 2.有关键字集合:{19,14,23,01,68,20,84,27,55,11,10,79},哈希函数:H(key)=key mod 13,采用链地址散列方法解决溢出。要求: 构造哈希表;搜索元素27,55所花的比较次数各是多少? * * * 第 7 章 跳表和散列 (Skip List and Hashing) * 本章内容 7.1 字典 7.2 线性表描述 7.3 跳表描述 7.4 散列表描述 7.5 应用 * * 散列表Hash Table 散列是计算机科学的一个伟大发明,它是由数组、表和一些数学方法相结合,构造起来的一种能够有效支持动态数据的存储和提取的结构。 典型应用是符号表,在一些值(数据)与动态的字符串(关键码)集合的成员间建立一种关联。 * * 散列的思想 散列表的思想是把关键码送给一个散列函数,产生一个散列值,这种值平均分布在一个适当的整数区间中。 散列值被用作存储信息的表的下标。 散列函数关键码————地址(固定,连续空间) * 7.4.1 理想散列 散列(Hashing) :字典的另一种描述方法就是散列 散列方法, 是用一个散列函数(hash function)把关键字映射到散列表/哈希表(hash table)中的特定位置。 理想情况 :如果散列函数为f 元素e 的关键字为k f 是散列函数 e 在散列表中的位置为f(k) 散列表操作: 搜索(Search):计算出f (k),然后看表中f (k)处是否有元
您可能关注的文档
- 互联网内容资源调度V3.pptx
- 06章风险投资的风险资本.ppt
- 互联网渠道二季度推广思路.pptx
- 06章输入输出与中断系统选读.ppt
- 互联网时代与营销创新2016资料.pptx
- 06中文版中医“治未病”思想选读.ppt
- 第3章计算机中信息的表示与存储资料.pptx
- 06重大危险源监督管理标准选读.doc
- 第3章数据处理资料.pptx
- 互联网医疗思考资料.pptx
- springbooot+vue基于java的房屋维修系统毕业论文.doc
- 中国消防救援学院《单片机系统实验》2023-2024学年第一学期期末试卷.doc
- 2025年溧阳纺织化学品项目申请.pptx
- 景区门票包销合同模板(3篇).docx
- 【股票技术指标学习指南】第七章第三节货币需要量的测算.doc
- 2025春 _ 人教版七年级英语下册【unit4】看音标写单词.doc
- 2025春 _ 人教版七年级英语下册【unit5】看音标写单词.doc
- 2025春 _ 人教版七年级英语下册【unit6】看音标写单词.doc
- 2025春 _ 人教版七年级英语下册【unit7】看音标写单词.doc
- 2025春 _ 人教版七年级英语下册【unit8】看音标写单词.doc
最近下载
- 佳能 G1000 1500 1800 2000 2800 3000 3800 维修手册.pdf VIP
- 2025贵州七星关区洪山街道中心校(毕节四小)教师“跨校竞聘”工作笔试参考题库附答案解析.docx VIP
- 2025贵州毕节七星关区碧阳街道中心校(毕节二十二小)教师“跨校竞聘”34人笔试参考题库附答案解析.docx VIP
- 2025贵州毕节七星关区实验学校教师“跨校竞聘”60人笔试参考题库附答案解析.docx VIP
- 2025贵州毕节七星关区德溪街道中心校(毕节市七星关区第五实验学校)教师“跨校竞聘”24人笔试备考题库及答案解析.docx VIP
- 肾性贫血治疗现状及特征(罗沙司他).pptx VIP
- 哮喘慢阻肺重叠综合征.ppt VIP
- 王文娟首演版越剧《孟丽君》剧本.doc VIP
- 小学教研讲座专题:如何教语文.ppt VIP
- 某物流园区项目施工组织设计方案措施.pdf VIP
文档评论(0)