[清航考研]暑期数据结构辅导-05;.docx

[清航考研]暑期数据结构辅导-05;.docx

  1. 1、本文档共60页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据结构辅导 第五章 查找 查找的概念 第五章 查找 顺序查找 折半查找 静态查找树 清华大学计算机系 殷人昆 索引结构与 树 B 散列法 清航考研 清航考研 查找(Search)的概念 在每个元素中有若干属性,其中有一个属性,其 ? ? 所谓查找,就是在数据集合中寻找满足某种条件 的数据元素。 值可唯一地标识这个元素。称为关键字( key)。 使用基于关键字的查找,查找结果应是唯一的。 ? 查找的结果通常有两种可能: 但在实际应用时,查找条件是多方面的,可以使 用基于属性的查找方法,但查找结果可能不唯一。 ? 查找成功,即找到满足条件的数据元素。这 时,作为结果, , 可报告该元素在结构中的位置 还可给出该元素中的具体信息。 ? 衡量一个查找算法的时间效率的标准是:在查找过程 中关键字的平均比较次数,也称为平均查找长度 ? 查找不成功,或查找失败。作为结果 , 一些信息,如失败标志、位置等。 应报告 ASL(Average Search Length) ,通常它是查找结构中 元素总数 的函数。 n 通常称用于查找的数据集合为查找结构,它是由 ? 静态查找常基于线性表,动态查找常基于树或字典。 ? 同一数据类型的元素(或记录)组成。 清航考研 清航考研 1 静态查找表结构的定义 顺序查找 (Sequential Search) #define maxSize 100 typedef int ElemType ; //查找表最大尺寸 //查找数据的类型 ? 所谓顺序查找 , 又称线性查找 , 构中进行查找。 主要用于在线性结 typedef struct { ElemType key; other; } ListNode; //查找表结点定义 //关键字域 //其他数据信息 ? 设若表中有 个元素,则顺序查找从表的先端 n (或后端) 开始,依次用各元素的关键字与给定 值x 进行比较,直到找到与其值相等的元素,则查 找成功;给出该元素在表中的位置。 typedef struct dataList { ListNode data[maxSize]; int n; } //查找表结点定义 //数据存储数组 //数组当前长度 ? 若整个表都已检测完仍未找到关键字与 相等的元 x 素, 则查找失败。给出失败信息。 清航考研 清航考研 设置“监视哨”的顺序查找算法 算法分析 int LinearSearch (dataList & L, ElemType x) { //在数据表L.data[0]..L.data[n-1]中顺序查找关键字 //值与给定值 x 相等的数据元素, L.data[n].key作为 //控制搜索自动结束的“监视哨”使用 L.data[L.n].key = x; int i = 0; //将 x 送表尾的下一个位置设置监视哨 while (L.data[i].key != x) i++; //从前向后顺序查找 return i; } ? ? 设查找第 p ,查找到第 i 个元素 i 个元素的概率为 i 所需比较次数为 c, 则查找成功的平均查找长度 i 为 : n-1 n -1 ∑ ∑ AS L = p ?c . ( p =1 ) succ i i i i= 0 i=0 在顺序查找并设置 监视哨 情形, “ ” c i … ,因此 , n-1 n-1 ASL p (i 1) succ = ∑ ? + succ = ∑ ? + i i=0 = i+1, i = 0, 1, 清航考研 清航考研 2 ? 设查找概率相等,即 p = 1 / n, i = 1, 2, i 查找成功的平均查找长度为: ASL succ = n -1 ∑ i=0 1 (i + 1) = nn 1 ? nn n(n+ 1) = 2 … n。则 , n+ 1 . 2 顺序查找的递归算法 int SeqSearch (dataList& L, ElemType x, int loc) { //在数据表L.data[0]..L.data[n-1]中查找其关键字值 //与给定值x匹配的元素, 函数返回其表中位置。 ? 而查找不成功时,一定把表中所有元素检测了一 遍,一直到监视哨。所以查找不成功的平均查找 //参数 loc 是在表中开始查找位置 if (loc >= L.n) return -1; //查找失败 ? 长度为:ASL = n+1 。 unsucc 顺序查找可以用递归方法实现。当查找表中第一 else if (L.data[loc].key == x) return loc; //查找成功 个元素即为所求,查找成功;否则对除第一个元 else return SeqSearch(L, x, loc+1); 素外的后续

文档评论(0)

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

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

1亿VIP精品文档

相关文档