第九章 查找
合集下载
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
s 2
查找方法比较
顺序查找 ASL(平均查找长度)最大
折半查找 最小
分块查找 两者之间
表结构 有序表、无序表 有序表
分块有序表
存储结构 顺序存储结构 顺序存储结构 顺序存储结构
线性链表
线性链表
9.3 .1二叉排序树查找
一、概念
二叉排序树(Binary Sorting Tree),它或者是一棵空树, 或者是一棵具有如下特征的非空二叉树:
❖初始时,令low=1,high=n,mid=(low+high)/2 ❖让k与mid指向的记录比较
若k==r[mid].key,查找成功 若k<r[mid].key,则high=mid-1 若k>r[mid].key,则low=mid+1
❖重复上述操作,直至low>high时,查找失败
算法描述
high low
1 2 3 4 5 6 7 8 9 10 11 5 13 19 21 37 56 64 75 80 88 92
判定树: 3
6 9
1
4 7 10
2
5 8 11
描述折半查找过程的判定树及查找21的过程
算法评价
❖判定树:描述查找过程的二叉树叫~
❖有n个结点的判定树的深度为log2n+1
❖折半查找法在查找过程中进行的比较次数最多不超过 其判定树的深度
监视哨 Ch7_1.c
ii
比较次数:
查找第n个元素: 1
查找第n-1个元素:2
……….
查找第1个元素: n
查找第i个元素: n+1-i
查找失败:
n+1
iii 比较次数=5
顺序查找方法的ASL
n
对含有n个记录的表, ASL pici i 1
设表中每个元素的查找
概率相等 pi
1 n
则ASL
n i 1
算法描述
Ch7_3.c
最大关键字 起始地址
索引表 22 48 86 1 7 13
查38
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 22 12 13 8 9 20 33 42 4ቤተ መጻሕፍቲ ባይዱ 38 24 48 60 58 74 57 86 53
分块查找方法评价
ASLbs Lb Lw 其中:Lb — —查找索引表确定所在块的平均查找长度
low
mid
high
1 2 3 4 5 6 7 8 9 10 11
5 13 19 21 37 56 64 75 80 88 92
low mid high 1 2 3 4 5 6 7 8 9 10 11 5 13 19 21 37 56 64 75 80 88 92
low high mid
1 2 3 4 5 6 7 8 9 10 11 5 13 19 21 37 56 64 75 80 88 92
❖若它的左子树非空,则左子树上所有结点的关键字均 小于根结点的关键字;
❖若它的右子树非空,则右子树上所有结点的关键字均 大于等于根结点的关键字;
❖左、右子树本身又都是一棵二叉排序树。
二、二叉排序树的数据类型描述
和第六章类似,可以用一个二叉链表来描述一棵二叉 排序树,具体为:
❖折半查找的ASL
设表长n 2h 1, h log 2 (n 1),即判定树是深度为h的满二叉树
设表中每个记录的查找概率相等pi
1 n
则:ASL
n i 1
pi ci
1 n
n
ci
i 1
1 n
h j 1
j 2 j1
n 1 n log 2 (n 1) 1 log 2 (n 1) 1
第九章 查找
查找——也叫检索,是根据给定的某个值,在表 中确定一个关键字等于给定值的记录或数据元素
关键字——是数据元素中某个数据项的值,它可
以标识一个数据元素
查找方法评价
❖查找速度 ❖占用存储空间多少 ❖算法本身复杂程度
n
对含有n个记录的表,ASL pici i 1
n
其中:pi为查找表中第i个元素的概率, pi 1 i 1
ci为找到表中第i个元素所需比较次数
❖平均查找长度ASL(Average Search Length):为确定 记录在表中的位置,需和给定值进行比较的关键字的 个数的期望值叫查找算法的~
§9.1 顺序查找
查找过程:从表的一端开始逐个进行记录的关键 字和给定值的比较
算法描述
找64
例 0 1 2 3 4 5 6 7 8 9 10 11 64 5 13 19 21 37 56 64 75 80 88 92
5 13 19 21 37 56 64 75 80 88 92
Ch7_2.c
lowmid high
找70 例 1 2 3 4 5 6 7 8 9 10 11
5 13 19 21 37 56 64 75 80 88 92
low
mid
123456 7
5 13 19 21 37 56 64
high 8 9 10 11 75 80 88 92
当n值较大时(n>50), 有次近似结果)
§9.3 分块查找(索引顺序表的查找)
查找过程:将表分成几块,块内无序,块间有序; 先确定待查记录所在块,再在块内查找
适用条件:分块有序表 算法实现
❖用数组存放待查记录,每个数据元素至少含有关键字域 ❖建立索引表,每个索引表结点含有最大关键字域和指
向本块第一个结点的指针
Lw — —在块中查找元素的平均查找长度 若将表长为n的表平均分成b块,每块含s个记录,并设表中每个记录的
查找概率相等,则:
(1)用顺序查找确定所在块:ASLbs
1 b
b j 1
j
1 s
s
i
i 1
b 1 2
s 1 2
1 (n 2s
s) 1
(2)用折半查找确定所在块:ASLbs
log
2
(
n s
1)
pi ci
1 n
n
i
i 1
1 n(n 1) n2
n 1 2
对查找概率不等的查找表,先对查找概率进行排序 优点:算法简单,适用面广 缺点:平均查找长度较大。
§9.2 折半查找
查找过程:每次将待查记录所在区间缩小一半 适用条件:采用顺序存储结构的有序表
算法实现
❖设表长为n,low、high和mid分别指向待查元素所在 区间的上界、下界和中点,k为给定值
找21 例 1 2 3 4 5 6 7 8 9 10 11
5 13 19 21 37 56 64 75 80 88 92
low
mid
123456 7 5 13 19 21 37 56 64
high
8 9 10 11 75 80 88 92
low
mid
high
1 2 3 4 5 6 7 8 9 10 11