other_____hash表及其应用_朱全民老师.pdf

  1. 1、本文档共27页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
other_____hash表及其应用_朱全民老师

HASH函数及其应用 雅礼 朱全民 问题一 • 读入n个正整数,每个数小于109 • 查询某个数是否在这n个数中出现 • 一共查询m次 • n=100000 • m=100000 in.txt out.txt 5 5个数 YES 8 YES 1 NO 6 3 5 3 询问3次 3 6 9 分析 • 这题可以先对n个数进行快速排序,然后对 于每次询问,用二分查找解决。 • 有没有更快的做法? 什么是HASH? • 哈希表是一种高效的数据结构。 • 散列方法是使用函数h将U映射到表T[0..m-1]的下标上 (m=O(|U|))。这样以U中关键字为自变量,以h为函数 的运算结果就是相应结点的存储地址。从而达到在O(1)时 间内就可完成查找。 一、整数的Hash函数构造方法(1) 1.直接取余法 关键字k除以m,取余数作为在Hash表中的 位置。函数表达式可以写成: h(k)=k mod m 一般m选择为素数 一、整数的Hash函数构造方法(2 ) 2 .乘积取整法 关键字k乘以一个在(0,1)中的实数(最好是无理 数),得到一个(0,1)之间的实数;取出其小数部 分,乘以m,再取整数部分,即得K在Hash表中 的位置。函数表达式可以写成: ( ) h(k ) M kA mod 1  例如A 5 −1 就是一个好的选择。 2 一、整数的Hash函数构造方法(3 ) 3.平方取中法 把关键字K平方,然后取中间的 log2 M 位作为Hash函数值 返回。由于K的每一位都会对其平方中间的若干位产生影 响,因此这个方法的效果也是不错的。但是对于比较小的 K值效果并不是很理想,实现起来也比较繁琐。为了充分 利用Hash表的空间,M最好取2的整数次幂。例如,表容量 4 M=2 =16,,关键值K=100,那么h(k)=8 回到问题一 n最多为100000 flag数组不开到109 ,但可以开flag[1..300000] 可用取余法 解决冲突 • 将数组改为链表 问题二 • 问题一中的正整数改称字符串 • (每个字符串的长度不超过20 ) • 还是输入n个字符串,一共m次询问 • in.txt • out.txt • 4 5个字符串 • YES • cat • NO • banana • NO • apple • dog • 3 询问3次 • banana •

文档评论(0)

wnqwwy20 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

版权声明书
用户编号:7014141164000003

1亿VIP精品文档

相关文档