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