《数据结构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文档。上传文档
查看更多
南京邮电大学计算机学院 陈慧南 2006年9月 template class T ResultCode HashTableT:: Remove(T x) { int pos; if(Find(x,pos)==Success) { ht[pos]=NeverUsed;return Success; } return NotPresent; } 南京邮电大学计算机学院 陈慧南 2006年9月 数据结构 Data Structures in C++ 南京邮电大学计算机学院 陈慧南 2006年9月 第8章 跳表和散列表 南京邮电大学计算机学院 陈慧南 2006年9月 8.1?? 字典 8.3 散列表?? 南京邮电大学计算机学院 陈慧南 2006年9月 8.1 字典 南京邮电大学计算机学院 陈慧南 2006年9月 字典 是记录的集合。 有重复记录的字典 允许字典中有多个相同关键字值的记录,在实现搜索、插入和删除操作时需要一个规则来消除歧义。 南京邮电大学计算机学院 陈慧南 2006年9月 8.3 散 列 表 南京邮电大学计算机学院 陈慧南 2006年9月 8.3.1 散列技术 散列表是表示集合和字典的另一种有效方法。它提供了一种完全不同的存储和搜索方式:通过将关键字值映射到表中某个位置上来存储元素,而后根据关键字值直接访问。 Loc(key)=h(key) 其中,Loc(key)表示关键字值为key的元素的存储位置。 (1)这个把关键字值映射到位置的函数h称为散列函数; (2)这样建立的表称为散列表。 南京邮电大学计算机学院 陈慧南 2006年9月 冲突和同义词 建立全国省、市、自治区的人口统计简表。 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是散列函数。具有相同散列函数值的关键字值,对该散列函数而言称为同义词 。 南京邮电大学计算机学院 陈慧南 2006年9月 冲突是不可避免的。 例一:关键字值集合有31个元素,如果我们选择一个有40个元素的记录数组的散列表,也就是说散列地址的范围从0到39。 C4031.31!=40!/9!?1042 4031?4*1049 31个元素 40个地址 南京邮电大学计算机学院 陈慧南 2006年9月 8.3.2 散列函数 均匀的散列函数 假定散列函数最多可取M个不同的值,即有0?h(key)M。一个均匀的散列函数应当是:如果key是从关键字值集合中随机选取的一个值,则h(key)以同等概率取区间[0,M-1]中的每一个值。 “好”的散列函数 一个实用的散列函数h应当满足下列条件: (1)能快速计算; (2)具有均匀性。 南京邮电大学计算机学院 陈慧南 2006年9月 常见的散列函数 (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; 南京邮电大学计算机学院 陈慧南 2006年9月 平方取中法 设关键字用内部码表示,内码采用八进制表示。 南京邮电大学计算机学院 陈慧南 2006年9月 字长W=2w,表长M=2k,w=18,k=9。 关键字值内码 内码的平方 散列地址 0100 0010000 010 1100 1210000 210 1200 1440000 440 南京邮电大学计算机学院 陈慧南 2006年9月 折叠法 key=12320324111220 若散列地址取3位,则key被划分为5段: 123 203 241 112 20 (a)移位法 (

文档评论(0)

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

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

1亿VIP精品文档

相关文档