- 1、本文档共22页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
HASHFUNCTION
ANDITSAPPLICATIONS121220074邱丰羽
目录CONTENTSNO.1HashFunction/散列函数NO.3Applications——MD5/散列函数应用NO.2HashAlgorithm/散列函数算法NO.4Applications——Shazam/散列函数应用
HashFunction是一种从任何一种数据中创建小的数字“指纹”的方法。散列函数把消息或数据压缩成摘要,使得数据量变小,将数据的格式固定下来。该函数将数据打乱混合,重新创建一个叫做散列值的指纹。散列值通常用来代表一个短的随机字母和数字组成的字符串。好的散列函数在输入域中很少出现散列冲突。在散列表和数据处理中,不抑制冲突来区别数据,会使得数据库记录更难找到。
目录CONTENTSNO.1HashFunction/散列函数NO.3Applications——MD5/散列函数应用NO.2HashAlgorithm/散列函数算法NO.4Applications——Shazam/散列函数应用
AvoidCollision避免冲突04AvalancheEffect雪崩效应05Agoodhashfunctionandimplementationalgorithmareessentialforgoodhashtableperformance,butmaybedifficulttoachieve.01UniformDistribution统一的计算方法03一个好的散列函数及其实现算法能够让散列表有更“好”的表现,但似乎很难找到02HashAlgorithm(Standard)
即hash(k)=k或hash(k)=a*k+b,其中a,b为常数随机数法(Random)取关键字或关键字的某个线性函数值为散列地址。直接寻址法foranytablesizes,moduloreduction(模运算简化),bitmasking(位屏蔽)Cryptographichashfunctions(加密散列函数)HashAlgorithm(Examples)
1线性探查法(Linearprobing)2二次探查法(Quadraticprobing)5跳房子散列(Hopscotchhashing)=1+44布谷鸟哈希(Cuckoohashing)3双散列法(Doublehashing)HashAlgorithm(CollisionSolutions)
Cuckoohashing算法使用hashA和hashB计算对应key的位置。当两个哈希任意位置为空,则选择一个位置插入
Cuckoohashing让两个哈希有位置为空时,则插入到空位置
Cuckoohashing当两个哈希位置均不为空时,随机选择两者之一的位置上keyx踢出,计算踢出的keyx另一个哈希值对应的位置进行插入,转至2执行
Cuckoohashing当再次插入位置为空时插入,仍旧不为空时,踢出这个keyy!可能会出现死循环!
目录CONTENTSNO.1HashFunction/散列函数NO.3Applications——MD5/散列函数应用NO.2HashAlgorithm/散列函数算法NO.4Applications——Shazam/散列函数应用
MD5即Message-DigestAlgorithm5(消息摘要算法第五版)的简称,是当前计算机领域用于确保信息传输完整一致而广泛使用的散列算法之一(又译哈希算法、摘要算法等),主流编程语言普遍已有MD5的实现。将数据(如一段文字)运算变为另一固定长度值,是散列算法的基础原理,MD5的前身有MD2、MD3和MD4。MD5是输入不定长度信息,输出固定长度128-bits的算法。经过程序流程,生成四个32位数据,最后联合起来成为一个128-bits散列。基本方式为,求余、取余、调整长度、与链接变量进行循环运算。得出结果。Applications——MD5
Applications——MD5(Stringhash)
MD5也可以为任何文件(不管其大小、格式、数量)产生一个同样独一无二的“数字指纹”,如果任何人对文件做了任何改动,其MD5值也就是对应的“数字指纹”都会发生变化。我们常常在某些软件下载站点的某软件信息中看到其MD5值,它的作用就在于我们可以在下载该软件后,对下载回来的文件用专门的软件(如WindowsMD5Check等)做一次MD5校验,以确保我们获得的文件与该站点提供的文件为同一文件。利用
您可能关注的文档
最近下载
- 2025届高考语文复习:信息类文本阅读 课件(共104张PPT).pptx VIP
- 中国农村留守儿童现状调查报告.docx VIP
- 凑十法填空练习2000题.pdf
- 清华大学104页《DeepSeek:从入门到精通》.pdf
- 邮政营业员(初级)职业资格鉴定参考试题库(含答案).docx
- 皮肤肿瘤-皮肤性病学.pptx VIP
- 新疆大学2025年研究生复试思想政治素质和品德考核表.doc
- 2023届上海杨浦区中考试题猜想数学试卷含解析.doc VIP
- 2024年平顶山职业技术学院单招职业技能测试题库及答案解析完整版720831696.pdf VIP
- 中国神经外科重症患者气道管理专家共识(2016年).pdf VIP
文档评论(0)