- 1、本文档共60页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 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)