哈希函数的构造方法-数据结构课程教学网站-绍兴文理学院.PPT

哈希函数的构造方法-数据结构课程教学网站-绍兴文理学院.PPT

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

(第十九讲) 绍兴文理学院 计算机系计算机应用教研室 AAA BBBB 一个毕业设计大数据量测试数据的产生 AAA BBBB AAA BBBB AAA BBBB AAA BBBB 第7章 查 找(3) 一、教学目的:明确哈希表的有关概念;掌握哈希函数的构造方法;掌握常用的处理冲突的方法;掌握哈希查找平均查找长度的计算;初步掌握用开放定址法和链地址法解决冲突的算法;了解几个不同的处理冲突方法下的平均查找长度的公式;算法设计训练。 二、教学重点:哈希表的有关概念;哈希函数的构造方法;常用的处理冲突的方法;用开放定址法和链地址法解决冲突的算法;哈希查找平均查找长度的计算;算法设计训练。 三、教学难点:哈希表的构造及解决冲突的算法;算法设计。 四、教学过程: AAA BBBB §7.4 散列表的查找 §7.4.1 散列表的基本概念 1、散列查找法 前面所讨论的查找方法是建立在“比较”的基础上的,查找的效率依赖于查找过程中所进行的比较次数。 理想的情况是希望不经过任何比较就能直接计算出记录的存储地址,从而找到所要查找的记录。 如果能在元素的存储位置和其关键字之间建立某种直接关系,按照这种关系直接由关键字找到相应的记录。这就是散列查找法( Hash Search)的思想。散列查找法又叫杂凑法或散列法。 2、相关概念 (1) 散列函数和散列地址: 在记录的存储位置p和其关键字key之间建立一个确定的对应关系何,使p=H(key),称这个对应关系H为散列函数,p为散列地址。 TKS * * AAA BBBB 一个有限连续的地址空间,用以存储按散列函数计算得到相应散列地址的数据记录。通常散列表的存储空间是一个一维数组,散列地址是数组的下标。 例1,假设有一批关键字序列18,75,60,43,54,90,46,给定哈希函数H(k)=k%13,存贮区的内存地址从0到15,则可以得到每个关键字的散列地址为: H(18)=18%13=5 H(75)=75%13=10 H(60)=60%13=8 H(43)=43%13=4 H(54)=54%13=2 H(90)=90%13=12 H(46)=46%13=7 根据散列地址,可以将上述7个关键字序列存贮到一个一维数组HT(哈希表或散列表)中,具体表示为: (2) 散列表: 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 HT 54 43 18 46 60 75 90 散列函数 散列地址 散列表 TKS * * AAA BBBB 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 HT 54 43 18 46 60 75 90 其中HT就是散列存贮的表,称为散列表或哈希表。从哈希表中查找一个元素相当方便,例如,查找75,只需计算出H(75)=75%13=10,则可以在HT[10]中找到75。 为了保证哈希表查找得以实现,必须使记录的存放规则和查找规则一致。 (3) 冲突和同义词: 对不同的关键字可能得到同一散列地址,即key1≠key2,而H(keyl)=H(key2),这种现象称为冲突。 具有相同函数值的关键字对该散列函数来说称作同义词,key1与key2互称为同义词。 例2 对C语言某些关键字集合建立一个散列表,关键字集合为: Sl={main,int,float,while,return,break,switch,case,do} 散列表定义为:char HT[26][8]; TKS * * AAA BBBB 设散列函数为:H(key)=key[0]-‘a’ while switch return main int float do case break 25 … 22 … 18 17 … 12 … 8 … 5 4 3 2 1 0 假设关键字集合扩充为: S2=Sl+{short,default,double,static,for, struct} 若散列函数不变,新加入的六个关键字经过汁算得到: H(short)=H(static)=H(struct)=18 H(default)=H(do

文档评论(0)

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

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

1亿VIP精品文档

相关文档