- 1、本文档共15页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
散列函数为:h(key)
* * * * * * * * * * * * * 第5章 散列查找 §5.1 引子 ?已有几种查找方法: 已经是相当不错的时间复杂度! 顺序查找 二分查找(静态查找) 二叉搜索树 为二叉查找树的高度 到底还有没有其他适应性广 而速度又快的查找方法呢? 第5章 散列查找 §5.1 引子 [例5.1] 在登录QQ的时候,QQ服务器如何核对你的身份,以确定你就是该号码的主人? 【分析】看看是否可以用二分法查找。 ? 十亿(109 ≈ 230)有效用户,用二分查找30次。 ? 十亿(109 ≈ 230) × 1K ≈ 1024G,1T连续空间。 ? 按有效QQ号大小有序存储:在连续存储空间中,插入和删除一个新QQ号码将需要移动大量数据。 用不了二分查找, 我们该怎么办? 第5章 散列查找 §5.1 引子 [例5.2] 查英文字典的过程——查询英文单词“zoo”,你为什么不用二分法,而直接从字典的后面找? ? 我们已经根据要查找的关键词“zoo”在脑子里经过了“计算”,得出该关键词所在的大致位置,这样就能更快地找到它。这个“计算”过程非常类似于本章将要介绍的散列查找中的“散列函数计算”。 ?查字典的过程结合了散列查找(用于初步定位)、二分查找(一般不是准确二分)和顺序查找(当很接近关键词的时候)等几种查找方法。 第5章 散列查找 §5.1 引子 [例5.3] 网上搜索。搜索引擎是如何如此神速地把我们需要的有关信息找到的? 【分析】主要数据结构是“倒排索引” -- “单词到文档”的映射关系。 如何在这个巨大无比的表格 中查找特定的关键词? Docs Terms 文档1 文档2 …… 文档m–1 文档m 关键词1 3: 1,12,20 0 …… 2: 1, 22 3: 9,40,52 关键词2 0 2: 11,22 …… 4: 9,20,32,65 5: 5,9,10,32,35 …… …… …… …… …… …… 关键词n–1 0 0 …… 5: 3,9,10,32,56 10: 5,6,19,..,44 关键词n 5: 1,9,20,22,55 0 …… 0 1: 7 【问题】如何能够在极短的时间内(比如1秒内)搜索到需要的关键词? 第5章 散列查找 §5.1 引子 ? 散列查找法的两项基本工作: 构造散列函数:确定关键词所在的存储位置的计算方法; ?解决冲突:当多个关键词所在的存储位置相同时的解决方法。 【答案】散列查找法是很好方法之一! ? 并且,期望查找的时间复杂度好于 , ——几乎是常量:O(1),即查找时间与问题规模无关! ? 当然,散列查找法也有缺点和局限性…… ?散列表的定义 形如“名字(Name)-属性(Attribute)”对的集合的“符号表(Symbol Table)”也叫做“散列表” (Hash Table,即哈希表)。 类型名称:符号表(SymbolTable) 数据对象集:符号表是“名字(Name)-属性(Attribute)”对的集合。 操作集:对于一个符号表Table ? SymbolTable,一个给定名字Name ? NameType,属性Attr ? AttributeType,以及正整数TableSize,符号表的基本操作主要有: 1、SymbolTable InitializeTable( int TableSize ):创建一个长度为TableSize的符号表; 2、Boolean IsIn( SymbolTable Table, NameType Name): 查找特定的名字Name是否在符号表Table中; 3、AttributeType Find( SymbolTable Table, NameType Name): 获取Table中指定名字Name对应的属性; 4、SymbolTable Modefy(SymbolTable Table, NameType Name, AttributeType Attr): 将Table中指定名字Name的属性修改为Attr; 5、SymbolTable Insert(SymbolTable Table, NameType Name, AttributeType Attr): 向Table中插入一个新名字Name及其属性Attr; 6、 SymbolTable Delete(SymbolTable Table, NameType Name): 从Table中删除一个名字Name及其属性。 3/22 §5.2 基本概念 第5章 散列查找 ?“散列(Hashing)” 的基本思想
您可能关注的文档
- 三类沥青路面结构力学响应的对比分析 - 长安大学学报.pdf
- 三峡电厂左岸励磁装置灭磁时序分析 - 中国励磁专业网.doc
- 三峡树坪滑坡动力学的有限元模拟 - 岩石学报.pdf
- 三峡库区马尾松林土壤呼吸的空间变异特征 - 华中农业大学学报.pdf
- 三相电能表现场校验仪 - 武汉恒新国仪科技有限公司.doc
- 三相电能计量芯片tm7752.pdf
- 三向应力状态下混凝土强度和变形特性研究 - 中国工程科学.pdf
- 三种数据挖掘算法在电子病历知识发现中的比较 - 武汉大学图书情报 .pdf
- 三种群网络舆论空间生态研究.pdf
- 三轴围压下煤岩吸附膨胀特性与渗透性动态变化 - 高校地质学报.pdf
- 场地脚手架工程施工方案(3篇).docx
- 2024年浙江省丽水市松阳县玉岩镇招聘社区工作者真题及参考答案详解一套.docx
- 2024年河南省郑州市惠济区古荥镇招聘社区工作者真题及答案详解一套.docx
- 2024年浙江省杭州市淳安县文昌镇招聘社区工作者真题及完整答案详解1套.docx
- 2024年浙江省台州市三门县小雄镇招聘社区工作者真题带答案详解.docx
- 2024年浙江省宁波市余姚市河姆渡镇招聘社区工作者真题及完整答案详解1套.docx
- 2024年浙江省丽水市景宁畲族自治县雁溪乡招聘社区工作者真题及答案详解一套.docx
- 2024年浙江省杭州市临安市板桥乡招聘社区工作者真题及答案详解一套.docx
- 2024年湖北省宜昌市点军区土城乡招聘社区工作者真题及答案详解一套.docx
- 2024年浙江省台州市路桥区桐屿街道招聘社区工作者真题附答案详解.docx
最近下载
- 新人教版高中物理必修第一册学案:2.2匀变速直线运动的速度与时间的关系.doc VIP
- 新生儿低氧血症的常规管理PPT课件.pptx VIP
- 高考英语句子成分及句子基本结构(共32张PPT).pptx VIP
- 药物成瘾教案.ppt VIP
- 广东省广州市五校2022-2023学年高一下学期期末联考物理试卷及参考答案.pdf VIP
- 海砂混凝土工程施工方案(3篇).docx VIP
- 2024年湖北省执业药师继续教育处方审核—中西药联合用药(3)答案.docx VIP
- 冷热疗法的效应.ppt VIP
- 卫生院优质服务基层行创建资料(4.8.1 信息公开).docx VIP
- 呼吸衰竭病人护理查房.pptx VIP
文档评论(0)