other_____hash表及其应用.pdfVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
other_____hash表及其应用

HASH函数及其应用 雅礼中学 朱全民 什么是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 二、字符串的Hash函数构造方法 • 字符串本身就可以看成一个256进制(ANSI字符 log M 串为128进制)的大整数,因此我们可以利用直接  2 取余法,在线性时间内直接算出Hash函数值。 n • 为了保证效果,仍然不能选择太接近2 的数;尤 p 其是当我们把字符串看成一个2 进制数的时候, 选择m= 2p -1会使得该字符串的任意一个排列的 Hash函数值都相同。 排列的Hash函数 • 让排列与数1--A(m,n)之间建立一一对应的关系。 n−1 ∗ • 引理 ∀n ∈N n! 1+∑k ⋅k ! k 1 • 从0到n!-1的任何自然数可唯一地表示为 ( ) ( ) m a n 1 ! a n 2 ! a 1! − + − + +  n−1 n−2 1 • 全排列与自然数之一一对应 不妨设n个元素为1,2,..,n。对应的规则如下:设序列 (a ,…, a ) 对应的某一排列,其中a 可以看做是排列p中数 n-1 1 i i+1所在位置右边比i+1小的数的个数。以排列4213为例,它 是元素1,2,3,4的一个排列。4的右边比4小的数的数目为3

文档评论(0)

qiwqpu54 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档