当前位置:文档之家› 数据结构之查找

数据结构之查找

第九章查找
一、选择题
1.若查找每个记录的概率均等,则在具有n个记录的连续顺序文件中采用顺序查找法查找一个记录,其平均查找长度ASL为( )。

A. (n-1)/2 B. n/2 C. (n+1)/2 , D. n
2.二分法查找只适用于查找顺序存储的有序表,平均比较次数为()。

在此假定N为线性表中结点数,且每次查找都是成功的。

A.N+1
B. log2N
C.Nlog2N
D.N2
3.下面关于二分查找的叙述正确的是 ( )
A. 表必须有序,表可以顺序方式存储,也可以链表方式存储
C. 表必须有序,而且只能从小到大排列
B. 表必须有序且表中数据必须是整型,实型或字符型
D. 表必须有序,且表只能以顺序方式存储
4当采用分快查找时,数据的组织方式为 ( )
A.数据分成若干块,每块内数据有序
B.数据分成若干块,每块内数据不必有序,但块间必须有序,每块内最大(或最小)的数据组成索引块
C. 数据分成若干块,每块内数据有序,每块内最大(或最小)的数据组成索引块
D. 数据分成若干块,每块(除最后一块外)中数据个数需相同
5.二叉查找树在 ( )时其查找效率最低
A. 结点太多
B. 完全二叉树
C. 呈单枝树
D. 结点太复杂。

6.分别以下列序列构造二叉排序树,与用其它三个序列所构造的结果不同的是( ) A.(100,80, 90, 60, 120,110,130) B.(100,120,110,130,80, 60, 90)
C.(100,60, 80, 90, 120,110,130)
D. (100,80, 60, 90, 120,130,110)
7.在平衡二叉树中插入一个结点后造成了不平衡,设最低的不平衡结点为A,并已知A的左孩子的平衡因子为0右孩子的平衡因子为1,则应作( ) 型调整以使其平衡。

A. LL
B. LR
C. RL
D. RR
8. 设有一组记录的关键字为{19,14,23,1,68,20,84,27,55,11,10,79},用链地址法构造散列表,散列函数为H(key)=key MOD 13,散列地址为1的链中有()个记录。

A.1 B. 2 C. 3 D. 4
9. 下面关于哈希(Hash)查找的说法正确的是( )
A.哈希函数构造的越复杂越好,因为这样随机性好,冲突小
B.除留余数法是所有哈希函数中最好的
C.不存在特别好与坏的哈希函数,要视情况而定
D.若需在哈希表中删去一个元素,不管用何种方法解决冲突都只要简单的将该元素删去即可
10. 若采用链地址法构造散列表,散列函数为H(key)=key MOD 17,则需 ( ) 个链表。

这些链的链首指针构成一个指针数组,数组的下标范围为 ( )
(1) A.17 B. 13 C. 16 D. 任意
(2) A.0至17 B. 1至17 C. 0至16 D. 1至16
11. 关于哈希查找说法不正确的有几个( )
(1)采用链地址法解决冲突时,查找一个元素的时间是相同的
(2)采用链地址法解决冲突时,若插入规定总是在链首,则插入任一个元素的时间是相同的
(3)用链地址法解决冲突易引起聚集现象
(4)再哈希法不易产生聚集
A. 1
B. 2
C. 3
D. 4
12. 设哈希表长为14,哈希函数是H(key)=key%11,表中已有数据的关键字为15,38,61,
84共四个,现要将关键字为49的结点加到表中,用二次探测再散列法解决冲突,则放入的位置是( )
A.8 B.3 C.5 D.9
13. 假定有k个关键字互为同义词,若用线性探测法把这k个关键字存入散列表中,至少要进行多少次探测?( )
A.k-1次 B. k次 C. k+1次 D. k(k+1)/2次
14. 哈希查找中k个关键字具有同一哈希值,若用线性探测法将这k个关键字对应的记录
存入哈希表中,至少要进行( )次探测。

A. k B. k+1 C. k(k+1)/2 D.1+k(k+1)/2
15. 散列函数有一个共同的性质,即函数值应当以( )取其值域的每个值。

A. 最大概率
B. 最小概率
C. 平均概率
D. 同等概率
16. 散列表的地址区间为0-17,散列函数为H(K)=K mod 17。

采用线性探测法处理冲突,并将关键字序列26,25,72,38,8,18,59依次存储到散列表中。

(1)元素59存放在散列表中的地址是( D )。

A. 8 B. 9 C. 10 D. 11
(2)存放元素59需要搜索的次数是( C )。

A. 2 B. 3 C. 4 D. 5
17. 将10个元素散列到100000个单元的哈希表中,则()产生冲突。

A. 一定会
B. 一定不会
C. 仍可能会
二、应用题
1.设有一组关键字{9,01,23,14,55,20,84,27},采用哈希函数:H(key)=key mod 7 ,表长为10,用开放地址法的二次探测再散列方法Hi=(H(key)+di) mod 10(di=12,22,32,…,)解决冲突。

要求:对该关键字序列构造哈希表,并计算查找成功的平均查找长度。

2. 已知散列表的地址空间为A[0..11],散列函数H(k)=k mod 11,采用线性探测法处理冲突。

请将下列数据{25,16,38,47,79,82,51,39,89,151,231}依次插入到散列表中,并计算出在等概率情况下查找成功时的平均查找长度。

三、算法设计
1、采用二分查找算法在有序表中ST中查找其关键字等于key的数据元素。

第九章查找
一、选择题
1-5 CBDBC 6-10 CCDC(AC) 11-15BDDCD 16-17(DC)C
二、应用题
1
succ
以关键字27为例:H(27)=27%7=6(冲突) H1=(6+1)%10=7(冲突)H2=(6+22)%10=0(冲突) H3=(6+33)%10=5 所以比较了4次。

2.
succ
三、算法设计
见书中220页算法9.2。

相关主题