Bootstrap

数据结构题库13

第七章 查找
一、单项选择题
1.在长度为n的线性表中进行顺序查找,在等概率的情况下,查找成功的平均查找长度是 (1) 。
(1):A.n B.n(n+1)/2 C.(n-1)/2 D.(n+1)/2
2.在长度为n的顺序表中进行顺序查找,查找失败时需与键值比较次数是 (2) 。
(2):A.n B.1 C.n-1 D.n+l
3.对线性表进行顺序查找时,要求线性表的存储结构是 (3) 。
(3):A.倒排表 B.索引表 C.顺序表或链表 D.散列表
4.对线性表用二分法查找时要求线性表必须是 (4) 。
(4):A.顺序表 B.单链表 C.顺序存储的有序表 D.散列表
5.在有序表A[80]上进行二分法查找,查找失败时,需对键值进行最多比较次数是 (5) 。
(5):A.20 B.40 C.10 D.7
6.在长度为n的有序顺序表中,采用二分法查找,在等概率的情况下,查找成功的平均查找长度是 (6)。
(6):A. O(n2) B.O(nlog2n) C.O(n) D.O(log2n)
7.设顺序表为{4,6,12,32,40,42,50,60,72,78,80,90,98},用二分法查找72,需要进行的比较次数是 (7) 。
(7):A.2 B.3 C.4 D.5
8.如果要求一个线性表既能较快地查找,又能适应动态变化的要求,则应采用的查找方法是 (8) 。
(8):A.顺序查找 B.二分法查找 C.分块查找 D.都不行
9.在采用线性探查法处理冲突的散列表中进行查找,查找成功时所探测位置上的键值 (9) 。
(9):A.一定都是同义词 B.一定都不是同义词
C.不一定是同义词 D.无任何关系
10.在查找过程中,若同时还要做插入、删除操作,这种查找称为 (10) 。
(10):A.静态查找 B.动态查找 C.内部查找D. 外部查找
二、填空题
1.在有序表A[30]上进行二分查找,则需要对键值进行4次、5次比较查找成功的记录个数分别为 (1) 、 (2) ,在等概率的情况下,查找成功的平均查找长度是 (3) 。
2.散列法存储的基本思想是由 (4) ,确定记录的存储地址。
3.对一棵二叉排序树进行 (5) 遍历,可以得到一个键值从小到大次序排列的有序序列。
4.对有序表A[80]进行二分查找,则对应的判定树高度为 (6) .,判定树前6层的结点个数为 (7) ,最高一层的结点个数是 (8) ,查找给定值K,最多与键值比较 (9) 次。
5.对于表长为n的线性表要进行顺序查找,则平均时间复杂度为 (10) ,若采用二分查找,则平均时间复杂度为 (11) 。
6.在散列表中,装填因子。值越大,则插入记录时发生冲突的可能性 (12) 。
7.在散列表的查找过程中与给定值K进行比较的次数取决于 (13) 、 (14) 和 (15)。
8.在使用分块查找时,除表本身外,尚需建立一个 (16) ,用来存放每一块中最高键值及 (17) 。
9.若表中有10000个记录,采用分块查找时,用顺序查找确定记录所在的块,则分成 (18)块最好,每块的最佳长度 (19) ,在这种情况下,查找成功的平均检索长度为 (20) 。
10.用n个键值构造一棵二叉排序树,最低高度是 (21) 。
11.设有散列函数H和键值k1、k2,若k1≠k2,且H(k1)= H(k2),则称k1、k2是 (22)。
12.设有n个键值互为同义词,若用线性探查法处理冲突,把这n个键值存于表长为m(m>n)的散列表中,至少要进行 (23) 次探查。
13.高度为6的平衡二叉排序树,其每个分支结点的平衡因子均为0,则该二叉树共有 (24)个结点。
14.m阶B-树,除根结点外的分支结点最多有 (25) 棵子树,最少有 (26) 棵子树,最多有 (27) 个键值,最少有 (28) 个键值。
15.m阶B+树,除根结点外的每个结点最多有 (29) 棵子树值,最少有 (30) 棵子树。
三、应用题
1.画出对长度为13的有序表进行二分查找的一棵判定树,并求其等概率时查找成功的平均查找长度。查找失败时需对键值的最多比较次数。
2.将整数序列{8,6,3,1,2,5,9,7,4}中的数依次插入到一棵空的二叉排序树中,求在等概率情况下,查找成功的平均查找长度,查找失败时对键值的最多比较次数。再画出从二叉排序树中删除结点6和8的结果。
3.将整数序列{8,6,3,1,2,5,9,7,41中的数依次插入到一棵空的平衡二叉排序树中,求在等概率情况下,查找成功的平均检索长度,查找失败时对键值的最多比较次数o
4.按不同的输入顺序输入4,5,6,建立相应的不同形态的二叉排序树。
5.设有键值序列{25,40,33,47,12,66,72,87,94,22,5,58}散列表长为12,散列函数为H(key)=key%11,用拉链法处理冲突,请画出散列表,在等概率情况下,求查找成功的平均查找长度和查找失败的平均查找长度。
6.已知一个散列函数为H(key)=key%13,采用双散列法处理冲突,H1(key)=key%11+1,探查序列为di=(H(key)+i* H1(key))%m,i=1,2,…m-1,散列表见表1,要求回答下列问题:
(1)对表中键值21,57,45和50进行查找时,所需进行的比较次数各为多少?
(2)在等概率情况下查找时,查找成功的平均查找长度是多少?
在这里插入图片描述
四、算法设计题
1.设二叉树用二叉链表表示,且每个结点的键值互不相同,请编写判别该二叉树是否为二叉排序树的非递归算法。

参考答案

第七章
一、单项选择题
(1)一(5) DDCCD (6)一(9) DCCC
二、填空题
(1)8 (2)15 (3) 4.3 (4)中序 (5)记录的键值 (6)7
(7)63 (8)17 (9)17 (10)O(n) (11)O(log2n) (12)越大
(13)散列函数 (14)处理冲突方法 (15) 装填因子 (16)索引表
(17)该块的起始地址 (18) 100 (19)100 (20)101 (21)log2(n+1)
(22)同义词 (23)n(n+1)/2 (24) 63 (25) m (26)m/2 (27)m-1
(28) m/2-1 (29)m (30)m/2
三、应用题
1.判定树见下图。
查找成功的平均查找长度
ASL=(1+22+34+4*6)/13=41/13
查找失败时与键值最多比较次数为4。
在这里插入图片描述

2.二叉排序树见右图。在等概率情况下,
查找成功的平均查找长度ASL=29/9≈3.2
查找失败时,与键值最多比较次数是5。
在这里插入图片描述

3.构造一棵平衡二叉排序树
的过程见右图。
等概率情况下,查找成功的平均查找长度
ASL=(1+22+34+4*2)/9≈2.8
查找失败时,与键值的最多比较次数是4。
在这里插入图片描述

4.按不同的输入顺序输入4、5、6,建立相应的不同形态的二叉排序树见下图。

在这里插入图片描述
5.键值序列:{25,40,33,47,12,66,72,87,94,22,5,58}
散列地址: 3 7 0 3 1 0 6 10 6 0 5 3
用拉链法处理冲突,构造的散列表如下图:
在这里插入图片描述
在等概率的情况下,查找成功的平均查找长度:
ASL=(7+23+32)/12=19/12=1.4
查找失败的平均查找长度:
ASL=(4+21+32)/12=1
6.已知散列表是:
在这里插入图片描述
查找key = 21 57 45 50
h0=key%13 = 8 5 6 11
d=key%11+1 = 11 3 2 7
h1=(h0+d)%13 = 6 8 8 5
h2=(h1+d)%13 = 10
查找成功比较次数 2 2 3 2
查找成功的平均查找长度ASL=(1+2+2+2+3)/5=2
四、算法设计
1.按中序遍历二叉排序树可得到一个按键值从小到大排列的有序表,利用这个特点来判别二叉树是否为二叉排序树,算法如下:
#define max 99
#define min 0
int judge(BTnode *bt)
{ BTnode *s[max],*p=bt;
int top=0,preval=min;
do {
while§
{s[top++]=p;
p=p->lchild;
}
if(top>0)
{p=s[–top];
if(p->data<preval)
return 0;
preval=p->data;
p=p->rchild;
}
}while(p||top>0)
return 1;
}

;