《数据结构A》第08章.pptVIP

  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文档。上传文档
查看更多
template class T ResultCode HashTableT:: Remove(T x) { int pos; if(Find(x,pos)==Success) { ht[pos]=NeverUsed;return Success; } return NotPresent; } 8.3.6 其它开地址法 基本聚集:许多元素在散列表中连成一片, 理想的探查序列应当是散列表位置的一个随机排列。以后搜索关键字时,须再生同样的探查序列。 二次探查法 探查序列: h(key),h1(key),h2(key),…,h2i-1(key),h2i(key),? h2i-1(key)=(h(key)+i2)mod M,i=1,2,3,…,(M-1)/2 h2i(key)=(h(key)-i2)mod M,i=1,2,3,…,(M-1)/2 式中,M是表的大小,它是一个值为4k+3的素数,k是整数,如503,1019等。 二次探查法都能够消除基本聚集。 二级聚集:相同的基位置,有同样的探查序列。 双散列法 使用双散列方法可以避免二级聚集 。 双散列法使用两个散列函数: h1: 计算探查序列的起始值 h2:计算下一个位置的探查步长 探查序列:H0,H1,H2,?为: h1(key), (h1(key)+h2(key))mod M, (h1(key)+2*h2(key))mod M,? 即: Hi=(h1(key)+i*h2(key))mod M i=0,1,…,M-1 h1(key)=key mod 11, h2(key)= key mod 9+1 数据结构 Data Structures in C++ 第8章 跳表和散列表 8.1?? 字典 8.3 散列表?? 8.1 字典 字典 是记录的集合。 有重复记录的字典 允许字典中有多个相同关键字值的记录,在实现搜索、插入和删除操作时需要一个规则来消除歧义。 8.3 散 列 表 8.3.1 散列技术 散列表是表示集合和字典的另一种有效方法。它提供了一种完全不同的存储和搜索方式:通过将关键字值映射到表中某个位置上来存储元素,而后根据关键字值直接访问。 Loc(key)=h(key) 其中,Loc(key)表示关键字值为key的元素的存储位置。 (1)这个把关键字值映射到位置的函数h称为散列函数; (2)这样建立的表称为散列表。 冲突和同义词 建立全国省、市、自治区的人口统计简表。 h(Hebei)=h(Henan)=h(Hubei)=h(Hunan)=8 h(Shandong)= h(Shanxi)= h(Shanghai)= h(Sichuan)=19 所谓冲突,是指对于关键字集合中的两个关键字值Ki和Kj,当Ki?Kj时,有h(Ki)=h(Kj),h是散列函数。具有相同散列函数值的关键字值,对该散列函数而言称为同义词 。 冲突是不可避免的。 例一:关键字值集合有31个元素,如果我们选择一个有40个元素的记录数组的散列表,也就是说散列地址的范围从0到39。 C4031.31!=40!/9!?1042 4031?4*1049 31个元素 40个地址 8.3.2 散列函数 均匀的散列函数 假定散列函数最多可取M个不同的值,即有0?h(key)M。一个均匀的散列函数应当是:如果key是从关键字值集合中随机选取的一个值,则h(key)以同等概率取区间[0,M-1]中的每一个值。 “好”的散列函数 一个实用的散列函数h应当满足下列条件: (1)能快速计算; (2)具有均匀性。 常见的散列函数 (1)除留余数法 除留余数法的散列函数的形式如下: h(key)=key mod M 其中,key是关键字,M是散列表的大小。 mod 是对模数求剩余。设M0,x mod M的值在[0,M-1] 中。 -6 mod 11=5,但-6%11=-6 使用 %实现mod运算的方法为: int pos=x % M;if (pos0) pos=M+pos; 平方取中法 设关键字用内部码表示,内码采用八进制表

文档评论(0)

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

1亿VIP精品文档

相关文档