数据结构练习3答案.docx
- 文档编号:5395105
- 上传时间:2022-12-15
- 格式:DOCX
- 页数:11
- 大小:75.65KB
数据结构练习3答案.docx
《数据结构练习3答案.docx》由会员分享,可在线阅读,更多相关《数据结构练习3答案.docx(11页珍藏版)》请在冰豆网上搜索。
数据结构练习3答案
数据结构练习〔三〕参考
一、选择题
1.顺序查找法适合于存储结构为的线性表
A〕哈希存储B〕顺序存储或链式存储
C〕压缩存储D〕索引存储
2.一个长度为100的已排好序的表,用二分查找法进行查找,假设查找不成功,至少比拟________次。
A〕9B〕8C〕7D〕6
3.采用顺序查找方法查找长度为n的线性表时,平均比拟次数为。
A〕nB〕n/2C〕〔n+1〕/2D〕〔n-1〕/2
4.对线性表进行折半查找时,要求线性表必须。
A〕以顺序方式存储B〕以顺序方式存储,且结点按关键字有序排列
C〕以链表方式存储D〕以链表方式存储,且结点按关键字有序排列
5.采用二分查找法查找长度为n的线性表时,每个元素的平均查找长度为。
A〕O〔n2〕B〕O〔nlog2n〕C〕O〔n〕D〕O〔log2n〕
6.有一个长度为12的有序表R[0…11],按折半查找法对该表进行查找,在表内各元素等概率查找情况下查找成功所需的平均比拟次数为。
A〕35/12B〕37/12C〕39/12D〕43/12
7.有一个有序表为{1,3,9,12,32,41,45,62,75,77,82,95,99},当采用折半查找法查找关键字为82的元素时,次比拟后查找成功。
A〕1B.2C〕4D〕8
8.当采用分块查找时,数据的组织方式为。
A〕数据分成假设干块,每块内存数据有序
B〕数据分成假设干块,每块内数据不必有序,但块间必须有序,每块内最大(或最小)的数据组成索引块
C〕数据分成假设干块,每块内数据有序,每块内最大〔或最小〕的数据组成索引块
D〕数据分成假设干块,每块〔出最后一块外〕中的数据个数需相同
9.采用分块查找时,假设线性表中共有625个元素,查找每个元素的概率相同,假设采用顺序查找来确定结点所在的块时,每块应有个结点最正确。
A〕10B〕25C〕6D〕625
10.不能生成右图所示二叉排序树的关键字序列是_____。
A〕45312B〕42531C〕45213D〕42315
11.按____遍历二叉排序树,可以得到按值递增或递减次序的关键码序列。
A〕先序B〕中序C〕后序D〕层序
12.在一棵平衡二叉树中,每个结点的平衡因子的取值范围是。
A〕-1—1B〕-2—2C〕1—2D〕0—1
13.具有5层结点的AVL树至少有个结点
A〕10B〕12C〕15D〕17
14.在含有15个结点的平衡二叉树上,查找关键字为28的结点,那么依次比拟的关键字可能是。
A〕30,36B〕38,48,28
C〕48,18,38,28D〕60,30,50,40,38,36
15.一棵深度为k的平衡二叉树,其每个非叶子结点的平衡因子均为0,那么该树共有个结点。
A〕2k-1-1B〕2k-1C〕2k-1+1D〕2k-1
16.查找效率最高的二叉排序树是。
A.所有结点的左子树都为空的二叉排序树
B.所有节点的右子树都为空的二叉排序树
C.平衡二叉树D.没有左子树的二叉排序树
17.下面关于B-树和B+树的表达中,不正确的结论是。
A〕B-树和B+树都能有效地支持顺序查找
B〕B-树和B+树都能有效地支持随机查找
C〕B-树和B+树都是平衡的多分支树
D〕B-树和B+树都可用于文件索引结构
18.设有n个关键字,哈希查找法的平均查找长度是。
A〕O〔1〕B〕O〔n〕C〕O〔log2n〕D〕O〔n2〕
19.将10个元素散列到100000个单元的哈希表,那么产生冲突。
A〕一定会B〕一定不会C〕仍可能会D〕以上都不对
20.设哈希表长m=14,哈希函数H〔key〕=keyMod11.表中已有4个结点H〔15〕=4,H〔38〕=5,H〔61〕=6,H〔84〕=7,其余地址为空,如用二次探测再散列法处理冲突,那么关键字为49的结点的地址是。
A〕8B〕3C〕5D〕9
21.假设有k个关键字互为同义词,假设用线性探测再散列法把这k个关键字存入哈希表中,至少要进行次探查。
A〕k-1B〕kC〕k+1D〕k〔k+1〕/2
22.假设采用链地执法构造哈希表,哈希函数为H〔key〕=keyMod17,那么需〔1〕个链表,这些链表的首指针构成一个指针数组,该数组的下标范围为〔2〕。
〔1〕A〕17B〕13C〕16D〕任意
〔2〕A〕0—17B〕1—17C〕0—16D〕1—16
23.直接插入排序在最好情况下的时间复杂度为。
A〕O〔n〕B〕O〔nlog2n〕C〕O〔log2n〕D〕O〔n2〕
24.稳定的排序算法是。
A〕直接插入排序B〕直接选择排序C〕堆排序D〕快速排序
25.数据序列{8,9,10,4,5,6,20,1,2}只能是算法的两趟排序后的结果。
A〕直接选择排序B〕冒泡排序C〕直接插入排序D〕堆排序
26.对数据序列{15,9,7,8,20,-1,4}进行排序,进行一趟后数据的排序变为{9,15,7,8,20,-1,4},那么采用的是算法。
A〕直接选择排序B〕冒泡排序C〕直接插入排序D〕堆排序
27.以下排序方法中,在初始序列已根本有序的情况下,排序效率最高。
A〕归并排序B〕直接插入排序C〕快速排序D〕堆排序
28.不稳定的排序方法是。
A〕冒泡排序B〕直接插入排序C〕希尔排序D〕归并排序
29.以下排序算法中,不能保证每趟排序至少能将一个元素放到其最终位置上。
A〕快速排序B〕希尔排序C〕堆排序D〕冒泡排序
30.在以下排序方法中,关键字比拟的次数与记录的初始排列次序无关的是。
A〕希尔排序B〕冒泡排序C〕插入排序D〕直接选择排序
31.在排序算法中,每次从未排序的记录中选取最小〔或最大〕关键字的记录,参加到已排序记录的末尾,该排序方法是。
A〕希尔排序B〕冒泡排序C〕插入排序D〕直接选择排序
32.采用直接选择排列,比拟次数与移动次数分别是。
A〕O〔n〕,O〔log2n〕B〕O〔log2n〕,O〔n2〕
C〕O〔n2〕,O〔n〕D〕O〔nlog2n〕,O〔n〕
33.以下序列不是堆的是。
A〕{100,85,98,77,80,60,82,40,20,10,66}
B〕{100,98,85,82,80,77,66,60,40,20,10}
C〕{10,20,40,60,66,77,80,82,85,98,100}
D〕{100,85,40,77,80,60,66,98,82,10,20}
34.堆排序是〔1〕类排序,堆排序平均时间复杂度和需要附加的存储空间复杂度分别是〔2〕。
〔1〕.A〕插入B〕交换C〕归并D〕选择
〔2〕.A〕O〔n2〕和O〔1〕B〕O〔nlog2n〕和O〔1〕
C〕O〔nlog2n〕和O〔n〕D〕O〔n2〕和O〔n〕
35.对n个记录的文件进行堆排序,最坏情况下的执行时间是。
A〕O〔log2n〕B〕〔n〕C〕O〔nlog2n〕D〕O〔n2〕
36.设有1000个无序的元素,希望用最快的速度挑选出其中前10个最大的元素,最好选用排序法。
A〕冒泡排序B〕快速排序C〕堆排序D〕基数排序
37.在非空m阶B-树上,除根结点以外的所有其他非终端结点。
A〕至少有
棵子树B〕至多有
棵子树
C〕至少有
棵子树C〕至少有
棵子树
38.对于哈希函数H(key)=key%13,被称为同义词的关键字是________。
A〕35和41B〕23和39C〕15和44D〕25和51
39.堆的形状是一棵________。
A〕二叉排序树B〕满二叉树C〕完全二叉树D〕不是二叉树
40.以下法在数据根本有序时效率最好。
A〕快速排序B〕冒泡排序C〕堆排序D〕希尔排序
41.快速排序在情况下最不利于发挥其长处。
A〕要排序的数据量太大B〕要排序的数据中含有多个相同值
C〕要排序的数据个数为奇数D〕要排序的数据已根本有序
42.以下序列中,__是执行第一趟快速排序后得到的序列(关键字为字符串)
A.[da,ax,eb,cd,bb]ff[ha,gc] B.[cd,eb,ax,da]ff[ha,gc,bb]
C.[gc,ax,eb,cd,bb]ff[da,ha] D.[ax,bb,cd,da]ff[eb,gc,ha]
43.一个记录的关键字为{46,79,56,38,40,84},采用快速排序以第一个记录为基准得到的第一次划分结果为________。
A〕{38,40,46,56,38,79,84}B〕{40,38,46,79,56,84}
C〕{40,38,46,56,79,84}D〕{40,38,46,56,79}
44.对以下关键字序列用快速排序法进行排序时,速度最快的情形是____。
A〕{21,25,5,17,9,23,30}B〕{25,23,30,17,21,5,9}
C〕{21,9,17,30,25,23,5}D〕{5,9,17,21,23,25,30}
45.以下排序方法中,在一趟结束后不一定能选出一个元素放在其最终位置上。
A〕直接选择排序B〕冒泡排序C〕归并排序D〕堆排序
46.将两个各有n个元素的有序表归并成一个有序表,其最少的比拟次数是。
A〕nB〕2n-1C〕2nD〕n-1
二、填空题:
1.在n个记录的有序顺序表中进行折半查找,最大的比拟次数是⎣log2n⎦+1。
2.设线性表{a1,,,a2,,…,a500}的元素的值从小到大排列,对一个给定的K的值用二分法查找线性表,在查找不成功的情况下至多需要比拟⎣log2n⎦+1次
3.在直接插入排序、希尔排序、直接选择排序、快速排序、堆排序和归并排序中,平均比拟次数最少的排序方法是快速排序。
4.一棵深度为h的B-树,任一个叶子结点所处的层数为h,当向B-树插入一个新关键字时,为检索插入位置需读取h-1个结点。
5.评价哈希表好坏的标准是哈希表的均匀性。
6.在各种查找方法中,其平均查找长度与结点个数n无关的查找方法是哈希表查找。
7.设用希尔排序对数序{98,36,-9,0,47,23,1,8,10,7}进行排序,给出的不长〔也称增量序列〕依次是4、2、1,那么排序需3趟,写出第一趟结束后,数序中数据的排列次序是10,7,-9,0,47,23,1,8,98,36。
三、判断题
1.顺序查找法适用于存储结构为顺序或链式存储的线性表
2.顺序查找方法只能在顺序存储结构上进行
3.折半查找可以在有序的双向链表上进行
4.分块查找的效率与线性表被分成多少块有关
5.在二叉排序树中,每个结点的关键字都比左孩子关键字大,比右孩子关键字小
6.每个结点的关键字都比左孩子关键字大,比右孩子关键字小,这样的二叉树都是二叉排序树
7.在二叉排序树中,新插入的关键字总是处于最低层
8.在二叉排序树中,新结点总是作为叶子结点来插入的
9.二叉排序树的查找效率和二叉排序树的高度有关
10.在平衡二叉排序树中,每个结点的平衡因子值都是相等的
11.在平衡二叉排序树中,以每个分支结点为根的子树都是平衡的。
12.哈希存储法只能存储数据元素的值,不能存储数据元素之间的关系。
13.哈希冲突是指同一个关键字对应多个不同的哈希地址。
14.哈希查找过程中,关键字的比拟次数和哈希表中关键字的个数直接相关。
15.在用线性探测法处理冲突的哈希表中,哈希函数值相同的关键字总是存在一片连续的存储单元中。
16.假设哈希表的装填因子a<<1,那么可防止冲突的发生。
17.哈希表的查找效率主要取决于哈希表造表时选取的哈希函数和处理冲突的方法。
四、简答题:
1.假设对具有n个元素的有序的顺序表和无序的顺序表分别进行顺序查找,试在下述两种情况下分别讨论两者在等概率时的平均查找长度;
〔1〕查找不成功,即表中无关键字等于给定值k的记录
〔2〕查找成功,即表中有关键字等于给定值k的记录
2.一个有序表为{12,18,20,25,29,32,40,62,83,90,95,98},当折半查找值29和90的元素时,分别需要多少次比拟才能查找成功?
假设采用顺序查找时〔从前往后找〕,分别需要多少次比拟才能成功?
4,4,5,10
3.比拟静态查找表的3种查找方法
4.请答复以下关于堆的问题
〔1〕堆的存储表示是顺序的,还是链接的?
〔2〕设有一个最小堆(小根堆),即堆中任意结点的关键字均小于它的左孩子和右孩子的关键字。
其具有最大关键字的元素可能在什么地方?
叶子
5.指出堆和二叉排序树的区别。
6.二叉排序树的结构如下图,其中各结点的关键字依次为32—40,请你标出各结点的关键字。
7.关键字序列为:
{1,2,6,7,11,4,8,13,10,5,17,9,16,20,3,12,14,16,18,19,15},创立一棵5阶B-树,对于该B-树,给出删除8,16,15,4等4个关键字的过程。
8.一组关键字为{21,33,12,40,68,59,25,51},试依次插入关键字生成一棵3阶B-树;如果此后删除40,画出每一步执行后B-树的状态。
9.哈希函数H(k)=2*kMod11,用二次探测再散列法处理冲突,为关键字序列〔6,8,10,17,20,23,53,41,54,57〕构造哈希表,并计算查找成功、不成功时的平均查找长度。
10.比拟直接插入排序和希尔排序的不同点。
11.在实现插入排序过程中,可以用折半查找来确定第i个元素在前i-1个元素中的可能插入位置,这样做能否改善插入排序的时间复杂度?
为什么?
12.在堆排序、快速排序和归并排序中:
〔1〕假设只从存储空间考虑,那么应首先选取哪种排序方法,其次选取哪种排序方法,最后选取哪种排序方法?
堆排序、快速排序、归并排序
〔2〕假设只从排序结果的稳定性考虑,那么应选取哪种排序方法?
归并排序
〔3〕假设只从平均情况下排序最快考虑,那么应选取哪种排序方法?
快速排序
〔4〕假设只从最坏情况下排序最快并且要节省内存考虑,那么应选取哪种排序方法?
堆排序
13.判别以下序列是否是大顶堆,如果不是,那么把它调整为大顶堆。
86,48,73,35,39,42,57,66,21,100
不是
14.哈希表地址空间为0到7,哈希函数为H(k)=k%8,采用线性探测再散列法和链地址法处理冲突,将以下各数依次存入该哈希表中,请分别构造哈希表,并分别计算平均查找长度。
240,29,345,189,100,20,21,35
ASL=〔1+1+1+2+1+4+6+1〕/8=17/8
ASL=〔1+1+1+1+2+1+2+3〕/8=12/8=0.75
15.请为17题数列构造一棵平衡的二叉排序树,并计算ASL。
ASL=(1+2*2+4*3+5*3)/10=32/10=3.2
16.有n个有序的数据构成一个数列,查找某个元素时最多要进行几次比拟?
当n=12,在等概率情况下查找成功的平均查找长度是多少?
[log2n]+1
ASL=(1+2*2+4*3+5*4)/12=37/12
17.对如下数据:
43,12,50,31,71,35,24,62,11,20
〔1〕写出采用快速排序算法的每一趟排序的结果
〔2〕写出执行直接插入排序算法,每趟排序的结果
〔3〕写出执行希尔排序算法,每趟排序的结果〔增量序列为5、3、1〕
〔4〕写出执行选择排序算法,每趟排序的结果
(1)43,12,50,31,71,35,24,62,11,20
{201211312435}42{627150}
{1112}20{312435}42{627150}
11122024313542{627150}
11122024313542506271
〔2〕43
1243
124350
12314350
1231435071
123135435071
12243135435071
1224313543506271
111224313543506271
11122024313543506271
〔3〕43,12,50,31,71,35,24,62,11,20
35125011204324623171
11123124204335625071
11122024313543506271
〔4〕43,12,50,31,71,35,24,62,11,20
11125031713524624320
11125031713524624320
11122031713524624350
11122024713531624350
11122024313571624350
11122024313571624350
11122024313543627150
11122024313543507162
11122024313543506271
五、算法设计题:
1.假设线性表中各节点的查找概率不等,那么可用如下策略提高顺序查找的效率,假设找到指定的结点,将该结点与其前驱〔假设存在〕结点交换,使得经常被查找的结点尽量位于表的前端。
设计出满足上述策略的顺序查找算法〔注意必须从表头开始向后扫描〕
2.设计一个算法,递增有序输出一棵二叉排序树的所有结点的关键字。
3.设计一个算法,从大到小输出二叉排序树中所有其他值不小于k的关键字。
4.设计一个算法,求出给定二叉排序树中最小和最大的关键字。
5.给定一组关键字,创立一个带头结点的单链表,设计一个直接插入排序算法对这个单链表进行递增序列。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据结构 练习 答案