数据结构 第九章 查找.ppt

数据结构第九章查找创新

9.2 静态查找表 9.3 动态查找表 9.4 哈希表 9.1 基本概念和术语 9.4 哈希表 9.4.1 什么是哈希表 9.4.2 哈希函数的构造方法 9.4.3 处理冲突的方法 9.4.4 哈希表的查找及其分析 9.4.1 什么是哈希表 前面两节讨论的表示查找表的各种结构的共同特点:记录在表中的位置和它的关键字之间不存在一个确定的关系; 查找的过程为给定值依次和关键字集合中各个关键字进行比较; 查找的效率取决于和给定值进行比较的关键字个数。 用这类方法表示的查找表,其平均查找长度都不为零。 不同的表示方法,其差别仅在于:关键字和给定值进行比较的顺序不同。 只有一个办法:预先知道所查关键字在表中的位置。即,要求:记录在表中的位置和其关键字之间存在一种确定的关系。 对于频繁使用的查找表,希望 ASL = 0。 若以下标为000 ~ 999 的顺序表表示之。 例如:为每年招收的 1000 名新生建立一张查找表,其关键字为学号,其值的范围为 xx000 ~ xx999 (前两位为年份)。 则查找过程可以简单进行:取给定值(学号)的后三位,不需要经过比较便可直接从顺序表中找到待查关键字。 但是,对于动态查找表而言,有以下问题: 因此在一般情况下,需在关键字与记录在表中的存储位置之间建立一个函数关系,

文档评论(0)

1亿VIP精品文档

相关文档