E.i++F.i--G.A和C同时满足H.B和D同时满足
5若入栈顺序为A、B、C、D、E,则下列(d)出栈序列是不可能的。
A.A、B、C、D、E B.B、C、D、A、E
C.C、D、B、E、A D.D、E、C、A、B
6递归程序可借助于(c)转化为非递归程序。
a.线性表b.队列c:
栈d.数组
7在下列数据结构中(c)具有先进先出(FIFO)特性,
(b)具有先进后出(FILO)特性。
a.线性表b.栈c.队列d.广义表
8若对编号为1,2,3的列车车厢依次通过扳道栈进行调度,不能得到(e)的序列。
a:
1,2,3b:
1,3,2c:
2,1,3d:
2,3,1e:
3,1,2f:
3,2,1
9在计算递归函数时,如不用递归过程,应借助于(b)这种数据结构。
A.线性表B.栈C.队列D.双向队列
10若带头结点的链表只设尾结点指针。
下列选择中(c)最适用于队列。
A)单链表B)双向链表C循环单链表D)双向循环链表
11栈和队列的一个共同点是(c)。
A.都是先进先出B.都是先进后出
C.只允许在端点处插入和删除元素D.没有共同点
12循环队列用数组A[0..m-1]存放其元素值,设头尾指针分别为front和rear,则当前队列中
的元素个数是(c)。
A.rear-front-1B.Rear-front+1
C.(rear-front+m)%mD.Rear-front
13如下关于串的陈述中,正确的是(a,c)。
A.串是数据元素类型特殊的线性表B.串中的元素是字母
C.串中若干个元素构成的子序列称为子串D.空串即为空格串
14对字符串s=’data-structure’执行操作replace(s,substring(s,6,8),’bas’)
的结果是(b)。
a:
‘database’b:
‘data-base’c:
‘bas’d:
‘data-basucture’
15设有二维数组A5x7,每一元素用相邻的4个字节存储,存储器按字节编址.
已知A的起始地址为100。
则按行存储时,元素A06的第一个字节的地址是(d)
按列存储时,元素A06的第一个字节的地址是(a)
a:
220b:
200c:
140d:
124
16对广义表A=((a,(b)),(c,()),d)执行操作gettail(gethead(gettail(A)))
的结果是:
(b)。
a:
()b:
(())c:
dd:
(d)
17假设用于通讯的电文仅由6个字符组成,字母在电文中出现的频率分别为7,19,22,6,32,
14。
若为这6个字母设计哈夫曼编码(设生成新的二叉树的规则是按给出的次序从左至
右的结合,新生成的二叉树总是插入在最右),则频率为7的字符编码是(g),频率
为32的字符编码是(c)。
a:
00b:
01c:
10d:
11
e:
011f:
110g:
1110h:
1111
18对二叉排序树(c)可得到有序序列。
a:
按层遍历b:
前序遍历c:
中序遍历d:
后序遍历
19设一棵二叉树BT的存储结构如下:
12345678
lchild23006000
dataABCDEFGH
rchild05408700
其中lchild,rchild分别为结点的左、右孩子指针域,data为结点的数据域。
则
该二叉树的高度为(d);
第3层有(a)个结点(根结点为第1层)。
A.2B.3C.4D.5
20先序遍历图示二叉树可得到(a)的序列。
(A)
/\
(B)(C)
/\\
(H)(D)(G)
/\
(E)(F)
\
(I)
a)ABHDEFICG
b)HBEDFIACG
c)HEIFDBGCA
21在有n个结点的二叉树的二叉链表表示中,空指针数为n+1;非空指针树为n-1;(b)。
a.不定b.n+1c.nd.n-1
22若某二叉树有20个叶子结点,有20个结点仅有一个孩子,则该二叉树的总结点数是
(c)。
度为2的节点n2=n0–1;其中no表示度为0的节点
A.40B.55C.59D.61
23已知某二叉树的先序遍历次序为abcdefg中序遍历次序为badcgfe,
则该二叉树的后序遍历次序为(c)。
层次遍历次序为(a)。
a:
abcdefgb:
cdebgfac:
bdgfecad:
edcgfba
.24图示的三棵二叉树中(c)为最优二叉树。
A)B)C)
ca
27
abcddb
752445
abcd
7524
25已知某二叉树的后序遍历和中序遍历次序分别为DBFGECA和BDACFEG。
则其先序遍历次序为(b),层次遍历次序为(a)。
a:
abcdefgb:
abdcefgc:
abcdfegd:
abcdegf
26已知某树的先根遍历次序为abcdefg后根遍历次序为cdebgfa。
若将该树转换为二叉树,其后序遍历次序为(d)。
a:
abcdefgb:
cdebgfac:
cdegbfad:
edcgfba
27设x和y是二叉树中的任意两个结点,若在先根序列中x在y之前,而在后根序列中x
在y之后,则x和y的关系是(c)。
A.x是y的左兄弟B.x是y的右兄弟
C.x是y的祖先D.x是y的子孙
28用三叉链表作二叉树的存储结构,当二叉树中有n个结点时,有(d)个空指针。
A.n-1B.nC.n+1D.n+2
29对一棵完全二叉树进行层序编号。
则编号为n的结点若存在右孩子,其位序是(d)。
编号为n的结点若存在双亲,其位置是(a)。
a:
n/2b:
2nc:
2n-1d:
2n+1e:
nf:
2(n+1)
30设森林F中有三棵树,第一、第二和第三棵树的结点个数分别为m1、m2和m3,则与
森林F对应的二叉树根结点的右子树上的结点个数是(d)。
A.m1B.m1+m2C.m3D.m2+m3
31下列二叉树中,(a)可用于实现符号不等长高效编码。
a:
最优二叉树b:
次优查找树c:
二叉平衡树d:
二叉排序树
32邻接表存储结构下图的深度优先遍历算法类似于二叉树的( a)遍历。
A.先根 B.中根 C.后根 D.层次
33设无向图G=(V,E)和G’=(V’,E’),若G’是G的生成树,则下面不正确的说法是(b)。
A.G’是G的子图 B.G’是G的连通分量(极大连通子图称为连通分量)
C.G’是G的无环子图 D.G’是G的极小连通子图且V’=V
34任何一个连通图的最小生成树(b)。
最小生成树其实是最小权重生成树的简称
A.只有一棵B.有一棵或多棵C.一定有多棵D.可能不存在
efef
35深度优先遍历图使用了数据结构(b),而广度优先遍历图使用了数据结构(c)。
A)数组B)栈C)队列D)线性表
36已知某有向图的邻接表存储结构如图所示。
根据存储结构依教材中的算法其深度优先遍历次序为(d)。
广度优先遍历此序为(c)。
各强连通分量的顶点集为(h)。
有向图的极大强连通子图,称为强连通分量
a:
abcde.b:
edcba.c:
ecdab.d:
ecadb.
e:
abc及edf:
bc及aedg:
ab及cedh:
ac及bed
37下列查找方法中(a)适用于查找单链表。
A)顺序查找B)折半查找C)分块查找D)hash查找
38下列算法中(c普利姆算法)适用于求图的最小代价生成树。
(b)能对图作广度优先遍历。
A)DFS算法B)BFS算法C)Prim算法D)Dijkstra算法
39关键路径是指在只有一个源点和一个汇点的有向无环网中源点至汇点(c)的路径。
a:
弧的数目最多b:
弧的数目最少c:
权值之和最大d:
权值之和最小
40希表的查找效率取决于(d)。
a:
哈希函数b:
处理冲突的方法。
c:
哈希表的装填因子。
d:
以上都是
41在Hash函数H(k)=kMODm中,一般来说,m应取( c)。
A.奇数B.偶数C.素数D.充分大的数
42在顺序表查找中,为避免查找过程中每一步都检测整个表是否查找完毕,
可采用a方法。
A.设置监视哨B.链表存贮C.二分查找D.快速查找
43静态查找表和动态查找表的区别在于(b)。
A.前者是顺序存储,而后者是链式存储
B.前者只能进行查找操作,而后者可进行查找、插入和删除操作
C.前者只能顺序查找,而后者只能折半查找
D.前者可被排序,而后者不能被排序
44在一个含有n个元素的有序表上进行折半查找,找到一个元素最多要进行(b)次元素
比较。
A.log2(n)B.log2(n)+1C.log2(n+1)D.log2(n+1)+1
45设输入序列为20,45,30,89,70,38,62,19依次插入到一棵2-3树中(初始状态为空),
该B-树为(b)。
再删除38,该B-树为(f)。
(3062)(45)
(19,20)(3845)(70,89)(30)(70)
(1920)(38)(62)(89)
a:
b:
(4570)(45)
(20)(62)(89)(20)(70)
(19)(30)(19)(30,38)(62)(89)
c:
d:
(3070)(45)
(19,20)(4562)(89)(20)(70)
(19)(30)(62)(89)
e:
f:
46根据插入次序(80,90,100,110,85,70,75,60,72)建立二叉排序树。
图(a)是最终变化的结果。
若仍以该插入次序建立平衡二叉树。
图(c)是最
终变化的结果。
8080
70907590
607585100607085100
7211072110
a:
b:
9090
7510080100
7080110757085110
6072856072
c:
d:
47若有序表中关键字序列为:
14,20,25,32,34,45,57,69,77,83,92。
画出二叉判定树计算,关键字在第几层,就经过几次比较对其进行
折半查找,则在等概率情况下,查找成功时的平均查找长度是(c)。
查找32时需进
行(c)次比较。
A.1B.2C.3D.4
48已知哈希表地址空间为A[9],哈希函数为H(k)=kmod7,采用线性探测再散列处理冲突指加数为1。
若依次将数据序列:
76,45,88,21,94,77,17存入该散列表中,则元素17存储的下标为(h);
在等概率情况下查找成功的平均查找长度为(c)。
A.0B.1C.2D.3
E.4F.5G.6H.7
49若从二叉树的根结点到其它任一结点的路径上所经过的结点序列按其关键字递增有序,
则该二叉树是(c)。
A.二叉排序树B.赫夫曼树C.堆D.平衡二叉树
50当待排序序列的关键字次序为倒序时,若需为之进行正序排序,下列方案中(d)为佳。
A.起泡排序B.快速排序
C.直接插入排序D.简单选择排序
51下列排序算法中,(d)算法可能会出现:
初始数据有序时,花费的时间反而最多。
A.堆排序B.起泡排序C.归并排序D.快速排序
52在下列排序方法中,(c快速排序)方法平均时间复杂度为0(nlogn),
最坏情况下时间复杂度为0(n2);(d)方法所有情况下时间复杂度均为0(nlogn)。
a.插入排序b.希尔排序c.快速排序d.堆排序
53已知一组待排序的记录关键字初始排列如下:
56,26,86,35,75,19,77,58,48,42
下列选择中(d)是快速排序一趟排序的结果。
(c)是希尔排序
(初始步长为3)一趟排序的结果。
(a)是初始堆(大堆顶)。
A)86,75,77,58,42,19,56,35,48,26.
B)26,56,35,75,19,77,58,48,42,86.
C)35,26,19,42,58,48,56,75,86,77.
D)42,26,48,35,19,56,77,58,75,86.
三.填空题
1数据结构通常有下列4类基本结构:
集合、线性结构、树型结构、图型结构。
2设单链表中结点形式为datanext,若单链表长度大于等于2,指针p指向表中某个结点且p->next非空,此时若要删除指针p所指的结点,可以通过如下方法进行:
将p所指结点的后继的元素值复制到该结点,然后删除其后继结点。
相应的语句序列为:
p->data=p->next->data;p->next=p->next->next;free(p->next)换指针的同时还要交换数据
3线性表的顺序存储结构是以数组下标来表示数据元素之间的逻辑关系的。
4已知P是单链表中某一结点的指针,P既不是首元结点也不是尾元结点,Q是P的前驱
结点指针。
当删除P结点时,链表的链接可用语句(q->netx=p->next)实现。
5已知某树的先根遍历次序为abcdefg后根遍历次序为cdebgfa。
若将该树转换为二叉树,其后序遍历次序为()。
层次遍历次序为()。
6已知某二叉树的先序遍历次序为afbcdeg后序遍历次序为cedbgfa。
其后序遍历次序为()。
层次遍历次序为()。
7在二叉树的第i层上至少有_____1____个结点,至多有___2i-1___个结点,
深度为k的二叉树至多有_2i__-1_______个结点.
8对树的遍历有先序遍历树和后序遍历树。
若以二叉链表作树的存储结构,
则树的先序遍历可借用二叉树的遍历算法来实现,
而树的后序遍历可借用二叉树的中序遍历遍历算法来实现。
9设高度为h的二叉树上只有度为0和度为2的结点,则此类二叉树中所包含的结点数至少
是2*h-1,至多是满树。
10对任何一棵二叉树T,若其终端结点数为n0.度为2的结点为n2,则n0与n2的关系为
(n0=n2+1)。
11如果对完全二叉树中结点从1开始按层进行编号,设最大编号为n;那么,可以断定编
号为i(i>1)的结点的父结点编号为(i/2向下取整);所有编号(i>n/2)的结点为叶子结点。
12n个顶点的连通图至少有条边,至多有n*(n-1)/2条边,此时即是完全图
条边。
13对于图的存储结构有(数组表示法)、(邻接表法)(十字链表法)(邻接多重表法)等方法。
14在一个无向图的邻接表中,若表结点的个数是m,则图中边的条数是____m/2________条。
15若有序表中关键字序列为:
12,22,33,44,55,66,77,88,99对其进行折半查找,
则在等概率情况下,查找成功时的平均查找长度是()。
查找99时需进行()次比
较。
16在哈希表中,处理冲突的方法有开放定址法,再哈希表法,链地址法等。
17在二叉树的第i层上至少有_____个结点,至多有_____个结点,深度为k的二叉树至多有
个结点.
18对于一棵高度为K的二叉排序树,结点数最少可有个,最多可有个。
19用中序遍历