数据结构期末总复习题

数据结构期末总复习题
数据结构期末总复习题

套题1

一、选择题(每题2 分,共15题,总计30 分)

1 以下叙述中正确的是_____。

A 数组是数据的最小单位

B 数据对象就是一组数据元素的集合

C 顺序存储方式只能用于存储线形结构

D 树对应到的二叉树其根结点的右子树总是空的

2 一个数组的第一个元素的存储地址是100,每个元素长度为2,则第5个元素的存储地址是_____。

A 110

B 108

C 100

D 120

3 一个栈的入栈顺序是a,b,c,d,e,则其出栈顺序不可能是_____。

A a,b,c,d,e

B e,d,c,b,a

C d,c,e,a,b

D d,e,c,b,a

4栈的特点是_____。

A 先进先出

B 先进后出

C 随即存取

D 链式实现

5 一个队列的入队顺序是1,2,3,4,5,那么出队顺序是_____。

A 5,4,3,2,1

B 1,2,3,5,4

C 1,2,3,4,5

D 1,3,2,4,5

6 向一个长度为10的数组的第5个元素之前插入一个元素时,需向后移动_____个元素。

A 3

B 5

C 6 D7

7若一棵二叉树有101个结点,且无度为1的结点,则叶结点的个数为_____。

A 48

B 49

C 50

D 51

8 高度为6的完全二叉树中第4层结点的个数为_____。

A 2

B 4

C 8

D 16

9具有n个顶点的无向完全图,其边数为_____。

A n

B n(n-1)

C n(n-1)/2

D n2

10具有n个顶点的有向完全图,其边数为_____。

A n

B n(n-1)

C n(n-1)/2

D n2

11在有7个顶点的无向图中至少有_____条边才能确保该图连通。

A 1

B 6

C 7

D 21

12对于一个有n个顶点的无向图,若采用邻接矩阵表示法,则该矩阵的大小是_____。

A n-1

B n

C (n-1)2

D n2

13在序列1,10,12,15,23,40,66,77,85中利用直接查找,查找15所需的比较次数为_____。

A 2

B 3

C 4

D 6

14 采用顺序查找方法查找长度为n的线性表时,每个元素的平均查找长度为_____。

AO( n) B O(nlogn) C O(n2) D O(logn)

15 在待排序元素基本有序的前提下,效率最高的排序方法是_____。

A 插入排序

B 选择排序

C 快速排序

D 归并排序

二、填空题(每空2 分,共20空,总计40 分)

1 判定下列程序段的时间复杂度为_________________,其中语句A[i][j]频度为___________________ for(i=0;i

{

for(j=0;j<=n;j++)

A[i][j]=0;

B[j][i]=1;

}

2对线性表进行二分查找时,要求线性表必须_______________且______________。

3 对于一个头指针为head的带头结点的单链表,判定该链表为空的条件是__________________,对于一个不带头指针的单链表,判定该链表为空的条件是__________________。

4 在循环单链表中,头指针用head表示,队尾结点用p指向,那么p→next等于__________________。

5 在选择数据结构的存储结构时,为了方便地定位和读取某特定元素,数据结构宜采用__________形式,为了方便地进行数据元素的插入删除操作,数据结构宜采用__________形式。

6深度为5的二叉树,最多有___________个结点,最少有___________个结点。

7若深度为5的二叉树中仅有度为0的结点和度为2的结点,那么这棵二叉树最多有___________个结点,最少有___________个结点。

8 在线索二叉树中,若以ltag表示某结点的左标志域,以lch表示某结点的左孩子域,则结点t没有左子树的条件是。

9在含有个8结点的二叉链表中有_______个空链域。

10有_______个结点的二叉树将会呈现5种不同的表现形式。

11在无向图的邻接矩阵中,若A[i][j]=1,A[j][i]= _______________。

12如下图所示的有向图,顶点D的入度为,出度为,顶点D的度为。

三、操作题(共4题,总计20

1已知一棵二叉树如下图所示:

①写出该二叉树的先根遍历序列(2分)

②写出该二叉树的中根遍历序列(2分)

③判断正误:这棵二叉树的先根、中根、后根遍历序列中,叶子结点的相对次序保

持不变,其实,任意一棵二叉树,其叶子结点在先根、中根、后根遍历序列中的相

对次序都保持不变。(2分)

2 下面的程序段是一个在单链表表示的有序序列a,b,d,e中插入新值c并保持有序的算法,已知插入位置的前驱用p指向,请将程序段补充完整。(6分)

p

Status ListInsert_L(LinkList &L, char c) {

s=(LinkList)malloc(sizeof(LNode)); ; s →next=; p →next=; return OK; }//ListInsert_L

3下图为一个无向图G ,请给出该图从A 出发的两个可能的广度优先遍历序列

①(2分) ②(2分)

③ 画出该图的邻接矩阵表示(4分)

四、算法设计题(共1题,总计10分)

设有两个栈S1,S2都采用顺序栈方式,并且共享一个存储区[O..maxsize-1],为了尽量利用空间,减少溢出的可能,可采用栈顶相向,迎面增长的存储方式。试设计S1,S2有关入栈和出栈的操作算法。

套题2

一、选择题(每题2 分,共10题,总计20 分)

1 一个数组的第一个元素的存储地址是1000,每个元素长度为4,则第4个元素的存储地址是_____。 A 1004 B 1008 C 101

2 D 1016 2 一个栈的入栈顺序是a,b,c,d,e ,则其出栈顺序不可能是_____。 A a,b,c,d,e B e,d,c,b,a C d,c,e,a,b D d,e,c,b,a

3从一个具有n 个结点的单链表中查找值等于x 的结点,在查找成功的前提下,其平均比较次数为_____。 A n B n/2 C (n-1)/2 D (n+1)/2

4 在序列1,10,12,15,23,40,66,77,85中利用直接查找,查找15所需的比较次数为_____。 A 2 B 3 C 4 D 6

5 下列排序算法中不稳定的是_____。

A 堆排序

B 折半插入排序

C 直接插入排序

D 链式基数排序

6 向一个长度为100的数组的第45个元素之前插入一个元素时,需向后移动_____个元素。

A 45

B 46

C 55 D56

7若一棵二叉树有101个结点,且无度为1的结点,则叶结点的个数为_____。

A 48

B 49

C 50

D 51

8具有n个顶点的无向完全图,其边数为_____。

A n

B n(n-1)

C n(n-1)/2

D n2

9 下列关于图的描述,错误的是_____。

A 无向图中所有顶点的度数之和为边数之和的2倍

B 有向图中所有顶点的度数之和为边数之和的2倍

C 有向图中所有顶点的入度之和等于出度之和

D 具有n个顶点,n-1条边的无向图是连通图

10有关二叉树下列说法正确的是_____。

A 二叉树是度为2的树

B 一棵二叉树的度可以小于2

C 二叉树中至少有一个结点的度为2

D 二叉树中所有结点的度都为2

二、填空题(每空2 分,共12题,总计40 分)

1 判定下列程序段的时间复杂度为___________________,其语句频度为___________________

for(i=0;i

{

for(j=0;j<=n;j++)

A[i][j]=0;

B[j][i]=1;

}

2 在一个单链表中的p所指的结点之前插入一个s所指的结点的操作可以描述为:

s->next=____________________;

p->next=s;

t=p->data;

p->data=____________________;

s->data=____________________;

3 在插入排序、希尔排序、选择排序、快速排序、堆排序、归并排序和基数排序中,平均比较次数最少的

排序是____________________,需要内存容量最多的排序是____________________。

4 对线性表进行二分查找时,要求线性表必须___________________________。

5 对于一个头指针为head的带头结点的单链表,判定该链表为空的条件是__________________,对于一个不带头指针的单链表,判定该链表为空的条件是__________________。

6 数据的存储结构是指,设有一批数据元素,为了方便地定位和读取某特定元素,数据结构宜采用__________形式,为了方便地进行数据元素的插入删除操作,数据结构宜采用__________形式。

7 已知一棵二叉树,其先序序列为ABCDE,中序序列为CDBEA,则其后序序列为_。

8高度为6的二叉树,其结点个数最多为_____个,最少为_____个。

9在线索二叉树中,若以ltag表示某结点的左标志域,以lch表示某结点的左孩子域,则结点t没有左子树的条件是。

10在含有个20结点的二叉链表中有_______个空链域。 11 有_______个结点的二叉树将会呈现5种不同的表现形式。 12如下图所示的AOE -网,其关键路径为。

三、算法题(每题8分,共2题,总计16分)

1、关键字序列a,b,c ,d 的链式存储如下,编写算法,通过更改指针实现关键字序列a ,d ,c,b 的链式存储。

2、设计算法,现有一字符串“12468”(即该变量为字符数组,每个单元存放一个char 型的值,分别为1,2,4,6,8),若该字符串表示的是数值型的八进制数值,即(12468)8,设计算法将它转换为十进制数并输出。

四、操作题(每题6分,共4题,总计24分)

1、

②将该树转化为二叉树(3分)

2、设有一组关键字为{8,7,13,10,9,23,15},哈希函数为H(key)=key MOD 7,按开放定址的线性探测再散列解决冲突,即增量序列为1,2,3,…,构造表地址空间为0--9的哈希表。

①请画出该哈希表(3分)

②计算对关键字23进行查找时的查找长度并写出计算过程(3分)

3、下图为一个无向图G

①请给出该图的邻接表表示(3分)

②依据你所作的邻接表,从A出发,给出该图的深度优先遍历序列(3分)

4、下图所示为一棵3阶B-树

①请给出删除元素25之后的3阶B-树(3分)

②在①的基础上,给出插入15之后的3阶B-树(3分)

套题3

一、选择题(共10题,每题2分,共20分):

1、从逻辑上可以把数据结构分为()两大类。

A)动态结构、静态结构

B)顺序结构、链式结构

C)线性结构、非线性结构

D)初等结构、构造型结构

2、下面关于线性表的叙述中,错误的是哪一个?()A)线性表采用顺序存储,必须占用一片连续的存储单元。B)线性表采用顺序存储,便于进行插入和删除操作。

C)线性表采用链接存储,不必占用一片连续的存储单元。D)线性表采用链接存储,便于插入和删除操作。

3、设无向图的顶点个数为n,则该图最多有()条边。

A) n-1 B) n(n-1)/2 C) n(n+1)/2 D) 0

4、对线性表进行二分查找时,要求线性表必须()

A) 以顺序方式存储 B) 以顺序方式存储且元素有序C) 以链式方式存储 D) 以链式方式存储且元素有序

5、下面给出的四种排序法中( )排序法是不稳定性排序法。

A) 插入 B) 冒泡 C) 二路归并D) 堆

6、以下说法正确的是______。

A) 数据元素是数据的最小单位

B) 数据项是数据的最小单位

C) 数据结构是带有结构的各数据项的集合

D) 数据结构是带有结构的数据元素的集合

7、下列说法不正确的是()

A)图的遍历是从给定的源点出发每一个顶点仅被访问一次

B)遍历的基本算法有两种:深度遍历和广度遍历

C)图的深度遍历不适用于有向图

D)图的深度遍历是一个递归过程

8、若一棵二叉树具有10个度为2的结点,5个度为1的结点,则度为0的结点个数是()

A) 9B) 11C) 15D) 不确定

9、栈和队列的共同点是()

A) 都是先进先出B) 都是先进后出

C) 只允许在端点处插入和删除元素D) 没有共同点

10、有关二叉树下列说法正确的是()

A)二叉树的度为2

B)一棵二叉树的度可以小于2

C)二叉树中至少有一个结点的度为2

D) 二叉树中任何一个结点的度都为2

二、填空题(共15空,每空 2 分,共30分)

1、当一个AOV网用邻接表表示时,可按下列方法进行拓扑排序。

1)查邻接表中入度为______的顶点,并进栈;

2)若栈不空,则①输出栈顶元素Vj,并退栈;②查Vj的直接后继Vk,对Vk进行入度处理,处理方法是____ __;

3)若栈空时,输出顶点数小于图的顶点数,说明有______,否则拓扑排序完成。

2、给定一组数据{6,2,7,10,3,12}以它构造一棵哈夫曼树,则树深度为__________,带权路径长度WPL的值为__________。

3、在单链表p结点之后插入s结点的操作是:______ 。

4、设有一批数据元素,为了最快地存取某元素,数据结构宜采用__________结构,为了方便地插入一个数据元素,数据结构宜采用__________结构。

5、在一个无向图中,所有顶点的度数之和等于所有边数倍,在一个有向图中,所有顶点的入度之和等于所有顶点出度之和的倍。

6、对于一个头指针为head的带头结点的单链表,判定该表为空表的条件是_____。

7、二叉树的第i层上最多含有结点数为。

8、具有N个结点的二叉树,采用二叉链表存储,共有______个空链域。

9、一个有n(n>0)个结点的图,最少有个连通分量,最多有个连通分量。

三、算法题(共3题,每题5分,共15分)

1、写一算法,求带有头结点的单链表的表长。

2、请用非递归算法写出折半查找的算法。

3、请写出直接插入排序的算法。

四、操作题(共6题,第1题10分,其余每题5分,共35分)

1、输入一个正整数序列(53,17,12,66,58,70,87,25,56,60),试完成下列各题。(1)按次序构造一棵二叉排序树BS。(2) 依此二叉排序树,如何得到一个从大到小的有序序列?(3)画出在此二叉排序树中删除结点66后的树结构。(10分)

2、已知一组关键字为(19,14,23,01,68,20,84,27,55,11,10,79),则按哈希函数H(key)=key mod 13 和链地址法处理冲突构造哈希表。(5分)

3、对于下面的有向图G,请写出所有可能的拓扑序列。(5分)

4、已知一棵二叉树前序为ABDEGCF,中序为DBGEACF,画出这棵二叉树。(5分)

5、写出对数据(15,9,7,8,20,-1,7,4)进行快速排序中第一趟的序列。(5分)

6、无向图G=(V,E),其中:V={a,b,c,d,e,f},E={(a,b),(a,e),(a,c),(b,e),(c,f),(f,d),(e,

d)},写出对该图进行深度优先遍历的一个序列。(5分)

套题 4

一、选择题(共10题,每题2分,共20分):

1、以下属于逻辑结构的是()。

A)顺序表B)哈希表C)有序表D)单链表

2、下面关于线性表的叙述中,错误的是哪一个?()。

A)线性表采用顺序存储,必须占用一片连续的存储单元。

B)线性表采用顺序存储,便于进行插入和删除操作。

C)线性表采用链接存储,不必占用一片连续的存储单元。

D)线性表采用链接存储,便于插入和删除操作。

3、设无向图的顶点个数为n,则该图最多有()条边。

A) n-1B) n(n-1)/2 C) n(n+1)/2D) 0

4、线性表是具有n个()的有限序列(n>0)。

A) 表元素B) 字符C) 数据元素D) 数据项

5、下面给出的四种排序法中( )排序法是稳定性排序法。

A) 希尔B) 快速C) 二路归并D) 堆

6、若需在O(nlog2n)的时间内完成对数组的排序,且要求排序是稳定的,则可选择的排序方法是()。

A)快速排序B) 堆排序C)归并排序D)直接插入排序

7、下列说法不正确的是()。

A)图的遍历是从给定的源点出发每一个顶点仅被访问一次

B)遍历的基本算法有两种:深度遍历和广度遍历

C)图的深度遍历不适用于有向图

D)图的深度遍历是一个递归过程

8、若一棵二叉树具有14个度为2的结点,5个度为1的结点,则度为0的结点个数是()。

A) 9B) 11C) 15D) 不确定

9、若某线性表最常用的操作是存取任一指定序号的元素和在最后进行插入和删除运算,则利用()存储

方式最节省时间。

A) 顺序表B) 双链表

C) 带头结点的双循环链表D) 单循环链表

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

A)(n-1)/2B) n/2C) (n+1)/2D) n

二、填空题(共15空,每空 2 分,共30分)

1、数据的物理结构包括的表示和的表示。

2、给定一组数据{6,2,7,10,3,12}以它构造一棵哈夫曼树,则树深度为__________,带权路径长度WPL的值为__________。

3、在单链表p结点之后删除s结点的操作是:______ 。

4、设有一批数据元素,为了最快地存取某元素,数据结构宜采用__________结构,为了方便地插入一个数据元素,数据结构宜采用__________结构。

5、在拓扑排序中,拓扑序列的第一个顶点必须是________的顶点。

6、对于一个头指针为head的带头结点的单链表,判定该表为空表的条件是_____。

7、二叉树的第i层上最多含有结点数为。

8、具有N个结点的二叉树,采用二叉链表存储,共有______个空链域。

9、一个有n(n>0)个结点的图,最少有个连通分量,最多有个连通分量。

10、对于具有N个结点的完全二叉树,其深度为。

11、在长度为n的顺序表的第i个位置上插入一个元素(1≤i ≤n+1),元素的移动次数为。

三、算法题(共3题,每题5分,共15分)

1、请写一算法,求带有头结点的单向循环链表的表长。

2、请用非递归算法写出在二叉树中计算叶子结点个数的算法。

3、请写出简单选择排序的算法。

四、操作题(共6题,第1题10分,其余每题5分,共35分)

1、已知一组关键字为(19,14,23,01,68,20,84,27,55,11,10,79),则按哈希函数H(key)=key mod 13 和链地址法处理冲突构造哈希表。(10分)

2、请写出在如下具有11个数据元素的有序表中使用折半查找算法查找21的过程(关键字即为数据元素的值)。(5分)

(05,13,19,21,37,56,64,75,80,88,92)

3、对于下面的有向图G,请写出所有可能的拓扑序列。(5分)

4、写出对数据(49,38,65,97,76,13,27,49)进行快速排序中第一趟的序列。(5分)

5、无向图G=(V,E),其中:V={a,b,c,d,e,f},E={(a,b),(a,e),(a,c),(b,e),(c,f),(f,d),(e,

d)},写出对该图进行广度优先遍历的序列。(5分)

6、已知一棵二叉树前序为ABDEGCF,中序为DBGEACF,画出这棵二叉树。(5分)

套题5

一、选择题(每题2 分,共10题,总计20 分)

1.以下那一个术语与数据的存储结构无关?()

A.栈B. 哈希表C. 线索树D. 双向链表

2.对于一个头指针为head的带头结点的单链表,判定该表为空表的条件是()

A.head==NULL B.head→next== head

C.head→next== NULL D.head!=NULL

3. 对于栈操作数据的原则是()。

A. 先进先出

B. 后进先出

C. 后进后出

D. 不分顺序

4.若一棵二叉树具有10个度为2的结点,5个度为1的结点,则度为0的结点个数是()

A.9 B.11 C.15 D.不确定

5.树的后根遍历序列等同于该树对应的二叉树的( ).

A. 先序序列

B. 中序序列

C. 后序序列D.不一定

6.n个结点的完全有向图含有边的数目()。

A.n*n B.n(n+1)C.n/2 D.n*(n-l)

7.下列哪一种图的邻接矩阵是对称矩阵?()

A.有向图B.无向图C.AOV网D.AOE网

8. 下面关于哈希(Hash,杂凑)查找的说法正确的是( )

A.哈希函数构造的越复杂越好,因为这样随机性好,冲突小

B.除留余数法是所有哈希函数中最好的

C.不存在特别好与坏的哈希函数,要视情况而定

D.若需在哈希表中删去一个元素,不管用何种方法解决冲突都只要简单的将该元素删去即可

9.下列排序算法中,其中()是稳定的。

A. 堆排序,冒泡排序

B. 快速排序,堆排序

C. 直接选择排序,归并排序

D. 归并排序,冒泡排序

10堆是一种有用的数据结构。试判断下面的关键码序列中哪一个是堆( )

A.16,72,31,23,94,53 B.94,53,31,72,16,23

C.16,53,23,94,31,72 D.16,31,23,94,53,72

二、填空题(每空2 分,共20空,总计40 分)

1.在下面的程序段中,语句x+=1的频度是___________________,语句A[i][j]=1的频度是________________,整个程序的时间复杂度是___________________。

for(i=0;i

{

x+=1;

for(j=0;j<=n;j++)

A[i][j]=0;

B[j][i]=1;

}

2.在单链表指针为p的结点之后插入指针为s的结点,操作是__________________,

_______________________。

3.从逻辑上可以把数据结构分为_____和两大类。

4.一个队列的输入顺序是a ,b ,c ,d ,e ,则其输出序列为________________________。 5.一个具有N 个顶点,K 条边的无向图是一个森林(N > K ),则该森林必有_____棵树。 6.构造连通网最小生成树的两个典型算法是__________________和________________________。 7.设G 是一个非连通无向图,共有28条边,则该图至少有______个顶点。 8.若 (u, v) 是 E(G) 中的一条边,则称 u 与 v 互为__________。 9.一棵具有20个结点的完全二叉树的树高度(深度)是。 10.具有10个叶结点的二叉树中有个度为2的结点。 11.有3个结点的二叉树将会呈现种不同的表现形式。 12.N 个顶点的连通图的生成树含有______条边。

13.具有N 个结点的二叉树,采用二叉链表存储,共有个空链域。 14.二叉树中某一结点左子树的深度减去右子树的深度称为该结点的。

15.有一个长度为12的有序表,按二分查找法对该表进行查找,且查找每个元素的概率相同,则查找成功所需的平均查找长度为。

三、算法题(每题8分,共2题,总计16分)

1关键字序列a,b,c ,d 的链式存储如下,编写算法删除d 所在的结点,是删除之后的新序列为{a ,b ,e}。 其中结点定义为: struct node{ char data; struct node * next; };

2、①请写出快速排序的算法。(5分)

②对{503,87,512,61,908,170,897,275,653,462},以第一个记录为枢轴,写出按升序进行一趟快速排序的结果。(3分)

四、操作题(每题6分,共4题,总计24分)

1、已知某栈结构定义如下,现有一字符序列以{a ,b ,c ,d}的顺序进栈,试完成下 面的操作,使最终的输出序列为{a ,c ,b ,d} struct stack{ int base;

int top;

stactsize N;/*N>4*/ };

main (){ Init (stack); Push (a); ; ; ;

Pop; /*栈顶元素c 出栈*/ ; Push (d); Pop;

}/*end of main*/

2、假设一棵二叉树的先序序列为EBADCFHGIKJ 和中序序列为ABCDEFGHIJK 。 ①请画出该二叉树。(4分)

②将此二叉树转化成其对应的森林。(2分)

3、无向图G=(V,E),其中:V={a,b,c,d,e,f},E={(a,b),(a,e),(a,c),(b,e),(c,f),(f,d),(e,d)} ①请画出该图,并给出该图的邻接矩阵表示(4分)

②依据你所作的邻接矩阵,从A 出发,给出该图的深度优先遍历序列(2分)

4、将关键码DEC, FEB, NOV, OCT, JUL, SEP, AUG, APR, MAR, MAY, JUN, JAN 依次插入到一棵初始为空的AVL树中,画出每插入一个关键码后的AVL树。(6分)

套题6

一、选择题(共10题,每题2分,共20分)

1、对N个元素的表做顺序查找时,若查找每个元素的概率相同,则平均查找长度为( ) 。

A、(N+1)/2

B、N/2

C、N

D、[(1+N)*N ]/2

2、若长度为n的线性表采用顺序存储结构,在其第i个位置插入一个新元素的算法的时间复杂度为()(1<=i<=n+1)。

A、O(0)

B、O(1)

C、O(n)

D、O(n2)

3、循环队列存储在数组A[0..m]中,则入队时的操作为()。

A、rear=rear+1

B、rear=(rear+1) mod (m-1)

C、rear=(rear+1) mod m

D、rear=(rear+1)mod(m+1)

4、从逻辑上可以把数据结构分为()两大类。

A、动态结构、静态结构

B、顺序结构、链式结构

C、线性结构、非线性结构

D、初等结构、构造型结构

5、若一棵二叉树具有10个度为2的结点,5个度为1的结点,则度为0的结点个数是()

A、9

B、11

C、15

D、不确定

6、以下说法正确的是()。

A、数据元素是数据的最小单位

B、数据项是数据的最大单位

C、数据结构是带有结构的各数据项的集合

D、数据结构是带有结构的数据元素的集合

7、具有12个关键字的有序表,折半查找的平均查找长度()。

A、3.1

B、4

C、2.5

D、5

8、设无向图的顶点个数为n,则该图最多有()条边。

A、n-1

B、n(n-1)/2

C、n(n+1)/2

D、0

9、有关二叉树下列说法正确的是()

A、二叉树的度为2

B、一棵二叉树的度可以小于2

C、二叉树中至少有一个结点的度为2

D、二叉树中任何一个结点的度都为2

10、下面给出的四种排序法中( )排序法是不稳定性排序法。

A、插入

B、冒泡

C、二路归并

D、堆

二、判断题(共10题,每题1分,共10分)

1、当待排序记录已经从小到大排序或者已经从大到小排序时,快速排序的执行时间最省。()

2、完全二叉树一定存在度为1的结点。()

3、栈和队列都是线性表,只是在插入和删除时受到了一些限制。()

4、数据的逻辑结构是指数据的各数据项之间的逻辑关系。()

5、二叉树是一般树的特殊情形。( )

6、用向量和单链表表示的有序表均可使用折半查找方法来提高查找速度。()

7、线性表采用链表存储时,结点和结点内部的存储空间可以是不连续的。( )

8、链表是采用链式存储结构的线性表,进行插入、删除操作时,在链表中比在顺序存储结构中效率高。()

9、若输入序列为1,2,3,4,5,6,则通过一个栈可以输出序列3,2,5,6,4,1。()

10、对于有n个结点的二叉树,其高度为log2n。( )

三、填空题(共10空,每空2分,共20分)

1、设Q[0..N-1]为循环队列,其头、尾指针分别为P和R,则队Q中当前所含元素个数为_______。

2、在单链表L中,指针p所指结点有后继结点的条件是:__ 。

3、对于一个具有n个结点的单链表,在已知的结点p后插入一个新结点的时间复杂度为________,在给定值为x的结点后插入一个新结点的时间复杂度为________。

4、在单链表p结点之后插入s结点的操作是:___ ___ 、。

5、二叉树的第i层上最多含有结点数为。

6、在一个无向图中,所有顶点的度数之和等于所有边数倍,在一个有向图中,所有顶点的入度之和等于所有顶点出度之和的倍。

7、具有N个结点的二叉树,采用二叉链表存储,共有______个空链域。

四、程序填空题和算法设计题(共4题,每题5分,共20分)

1、以下程序的功能是在一个带有头结点的单链表L中,删除第i个元素,并由e返回其值的算法,请在画线部分填上代码。(5分)

StatusListDelete_L(LinkList&L,int i,ElemType &e)

//在带头结点的单链表L中,删除第i个元素,并由e返回其值

{p=L;

j=0;

while(p->next&&j

(1);

++j;

}

if(!(p->next) ||j>i-1) return ERROR;

(2);

p->next = q->next;

e=q->data;

free(q);

return OK;

}

2、以下程序的功能是在一有序表ST中折半查找其关键字等于key的数据元素。若找到,则函数值为该元素中的位置,否则为0,请在画线部分填上代码。(5分)

int Search_Bin(SSTable ST,KeyType key)

{ /* 在有序表ST中折半查找其关键字等于key的数据元素。若找到,则函数值为*/

/* 该元素在表中的位置,否则为0。*/

int low,high,mid;

low=1; /* 置区间初值*/

high=ST.length;

while(low<=high)

{

(1) ;

if EQ(key,ST.elem[mid].key) /* 找到待查元素*/

return mid;

else if LT(key,ST.elem[mid].key)

(2) ; /* 继续在前半区间进行查找*/

else

low=mid+1; /* 继续在后半区间进行查找*/

}

return 0; /* 顺序表中不存在待查元素*/

}

3、请用递归算法写出二叉树的先序遍历算法。(5分)

4、写一算法,求带有头结点的单链表的表长。(5分)

五、操作题

1、设一棵二叉树的前序序列为ABDGECFH,中序序列为:DGBEAFHC 。

(1)试画出该二叉树。(2)写出该二叉树的后序遍历序列。

(3)说明由二叉树的中序遍历序列和后序遍历序列是否可唯一地确定出该二叉树?

(4)说明由二叉树的前序遍历和后序遍历结果能否唯一确定一棵二叉树?(10分)

2、依次输入表(30,15,28,20,24,10,12,68,35,50,46,55)中的元素,生成一棵二叉排序树。

(1) 试画出生成之后的二叉排序树;(2) 对该二叉排序树作中序遍历,试写出遍历序列;

(3) 假定每个元素的查找概率相等,试计算该二叉排序树的平均查找长度。(10分)

3、写出对数据(49,38,65,97,76,13,27,49)进行快速排序中第一趟的序列。(5分)

4、无向图G=(V,E),其中:V={a,b,c,d,e,f},E={(a,b),(a,e),(a,c),(b,e),(c,f),(f,d),(e,

d)},写出对该图进行广度优先遍历的序列。(5分)

5、二叉树结点数值采用顺序存储结构,如下图所示:

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20

1)画出上述顺序存储结构所对应的二叉树表示形式;

2)写出前序遍历、中序遍历和后序遍历的结果;

3)写出结点C的双亲结点、其左、右孩子分别是什么;

若此树是由森林转换而成的二叉树,请将此二叉树还原成森林。

6、关键字序列{a,b,c,d,e,f,g,h}在某段文字中出现的频率分别是0.03,0.20,0.01,0.05,0.34,0.04,0.23,0.10。

要求:

(1)画出赫夫曼树;(3分)

(2)依据你所做的赫夫曼树,约定左分支表示字符‘1’,右分支表示字符‘0’,写出它的赫夫曼编码。(3分)

数据结构模拟题(开卷)

《数据结构》模拟题(补) 一.单项选择题 1.在线性表的下列存储结构中,读取元素花费时间最少的是【】。 A.单链表B.双链表C.顺序表D.循环链表 2.设计一个判定表达式中左、右括号是否配对出现的算法,采用【】数据结构最佳。 A.集合B.线性表C.队列D.栈 3.n个结点的线索二叉树上含有的线索数为【】。 A.2n B.n-1 C.n D.n+1 4.设广义表D=(a,(b,c)),则tail(D)=【】。 A.b,c B.(b,c) C.((b,c)) D.c 5.由4个结点可以构造出【】种不同的二叉树。 A.12 B.13 C.14 D.15 6.在栈中,出栈操作的时间复杂度为【】。 A.O(1) B.O(n) C.O(log2n) D.O(n2) 7.假设Q[0..len-1]表示循环队列,f为队头指针,r为队尾指针,则进队操作语句是【】。 A.f=f+1 B.r=r+1 C.f=(f+1)%len D.r=(r+1)%len 8.一个n*n的对称矩阵,如果以行或列为主序放入内存,则其容量为【】。 A.n*n B.n*n/2 C.n*(n+1)/2 D.(n+1)*(n+1)/2 9.队列操作的原则是【】。 A.进优于出B.出优于进C.先进先出D.后进先出 10.下列数据结构中,【】是非线性数据结构。 A.栈B.串C.队列D.树 11.两个指针p和q,分别指向单链表的两个元素,p所指元素是q所指元素的前驱,则【】。 A.p==q B.q->next=p C.p->next=q D.p->next=q->next 12.数组A中,每个元素的长度为4个字节,行下标i从1到5,列下标j从1到4,从首 地址SA开始连续存放在存储器内,该数组按行存放时,元素A[3][2]的起始地址为【】。 A.SA+20 B.SA+36 C.SA+40 D.SA+45 13.已知一个顺序存储的线性表,设每个结点需占m个存储单元,若第一个结点的地址为d1, 则第i个结点的地址为【】。 A.d1+(i-1)*m B.d1+i*m C.d1+(i+1)m D.d1-i*m 14.分析下列算法suanfa1(n)的时间复杂度是【】。 void suanfa1(int n) { int i,j,x=1; for(i=0;i

数据结构考试试题及答案

数据结构 一、单选题 1. 计算机算法指的是(b )。 A.程序B.问题求解步骤的描述C.调度方法D.排序方法 2. 以下数据结构中,(a )个是非线性数据结构。 A.树B.字符串C.队D.栈 3. 对于顺序存储的线性表,访问元素和插入元素的时间复杂度分别为:(c )。 A.O(n) O(n) B.O(n) O(1) C.O(1) O(n) D.O(1) O(1) 4. 在单链表指针为p的结点之后插入指针为s的结点,正确的操作是(b )。 A.p->next=s;s->next=p->next B.s->next=p->next; p->next=s C.p->next=s;p->next=s->next D.p->next=s->next; p->next=s 5. n个顶点的有向图中,含有向边的数目最多为( d ) A.n-1 B.n C.n(n-1)/2 D.n(n-1) 6. 循环队列存储在数组A[0..m]中,则入队时的操作为( d ) A.rear=rear+1 B.rear=(rear+1)mod(m-1) C.rear=(rear+1)mod m D.rear=(rear+1)mod(m+1) 7. 字符串?ababaabab?的next函数为(d ) A.011232232 B.012341234 C.011122334 D. 011234234 8. 若一棵二叉树具有10个度为2的结点,5个度为1的结点,则度为0的结点个数为( b )A.9 B.11 C.15 D.不确定 9. 设有数组A[i,j],数组的每个元素长度为3字节,i的值为1到8,j的值为1到10,数组从内存首地址BA开始顺序存放,当以列为主序存放时,元素A[5,8]的首地址为( b )。A.BA+141 B.BA+180 C.BA+222 D.BA+225 10. n个顶点的带权无向连通图的最小生成树包含(b )个顶点 A.n-1 B.n C.n/2 D.n+1 11.有关二叉树的下列说法正确的是( b ) A.二叉树的度为2 B.一棵二叉树的度可以小于2 C.二叉树中至少有一个结点的度为2 D.二叉树中任何一个结点的度都为2 12.关键路径是AOE网中( a )。 A.从源点到汇点的最长路径B.从源点到汇点的最短路径 C.最长回路 D.最短路径(从源点到汇点的所有路径中,经过弧的数目最多的路径) 13.若查找每个记录的概率相等,则在具有n个记录的连续文件中采用顺序查找查找一个记录,其平均查找长度ASL为(c)。 A.(n-1)/2 B.n/2 C.(n+1)/2 D.n 14.就平均性能而言,目前最好的内部排序方法是(d ) A.冒泡排序B.希尔排序C.堆排序D.快速排序 15.已知广义表LS=((a,b,c),(d,e,f)),运用head和tail函数取出LS中原子e的运算是(d )A.head(tail(LS)) B.tail (head (LS) C.head(tail(head(tail(LS)))) D.head(tail(tail (head (LS)))) 17.在n个结点的顺序表中,算法的时间复杂度是O(1)的操作是:( a ) A. 访问第i个结点(1≤i≤n)和求第i个结点的直接前驱(2≤i≤n) B. 在第i个结点后插入一个新结点(1≤i≤n)

数据结构期末复习题

数据结构期末复习题 一、单选题 1.设有两个串T和P,求P在T中首次出现的位置的串运算称作( )。 A.联接 B.求子串 C.字符定位 D.子串定位 2.8×8的整型数组A,其每个数组元素占2个字节,已知A[0][0]在内存中的地址是100,按列主序,A[5][6]的地址是( ) 。 A.192 B.206 C.92 D.106 3.一个具有767个结点的完全二叉树,其叶子结点个数为()。 A.383 B.384 C.385 D.386 4.具有65个结点的完全二叉树的高度为()。(根的层次号为0) A.8 B.7 C.6 D.5 5.一个数组元素a[i]与()的表示等价。 A.*(a+i) B.a+i C.*a+i D.&a+i 6.在一棵高度为h(假定树根结点的层号为0)的完全二叉树中,所含结点个数不小于( )。 A.2^(h-1) B.2^(h+1) C.2^(h-1) D.2^h 7. 已知广义表LS=((a,b,c),(d,e,f)),运用head和tail函数取出LS种元素e的运算是() A. head(tail(LS)) B. tail(head(LS)) C. head(tail(head(tail(LS)))) D. head(tail(tail(head(LS)))) 8.串S=’software’,其子串的数目是()。 A. 8 B. 37 C. 36 D. 9 9.当利用大小为n的数组顺序存储一个队列时,该队列的最大长度为()。 A. n-2 B. n-1 C. n D. n+1 10. 设有一个n*n的对称矩阵A,将其上三角部分按行存放在一个一维数组B中,A[0][0]存放于B[0]中,那么第i行的对角元素A[i][i]存放于B中()处。 A.(i+3)*i/2 B.(i+1)*i/2 C.(2n-i+1)*i/2 D.(2n-i-1)*i/2 11.在单链表中,指针p指向元素为x的结点,实现“删除x的后继”的语句是( ) 。 A.p=p->next; B.p->next=p->next->next; C.p->next=p; D.p=p->next->next; 12.下列算法的时间复杂度为()。 for ( i =1;i

数据结构模拟试题及答案

数据结构模拟试题一 一、判断题(每小题1 分,共15分) 1.计算机程序处理的对象可分为数据和非数据两大类。 2.全体自然数按大小关系排成的序列是一个线性表。 3.在描述单向链表的结点类型时,必须首先描述数值字段,然后再描述指针字段。 4.顺序栈是一种规定了存储方法的栈。 5.树形结构中的每个结点都有一个前驱。 6.在任何一棵完全二叉树中,最多只有一个度为1的分支结点。 7.若某顶点是有向图的根,则该顶点的入度一定是零。 8.如果某图的邻接矩阵有全零的行,没有全零的列,则该图一定是有向图。 9.用一维数组表示矩阵可以节省存储空间。 10.广义表的长度与广义表中含有多少个原子元素有关。 11.分块查找的效率与线性表被分成多少块有关。 12.散列表的负载因子等于存入散列表中的结点个数。 13.在起泡排序过程中,某些元素可能会向相反的方向移动。 14.按某种逻辑关系组织起来的记录的集合称为逻辑记录。 15.索引非顺序文件的特点是索引表中的索引项不一定按关键字大小有序排列。 二、填空题(每空1分,共15分) 1.顺序表是一种_____________线性表。 2.若用Q[1]~Q[m]作为非循环顺序队列的存储空间,则对该队列最多只能执行___次插入操作。 3.栈和队列的区别在于________的不同。 4.在高度为h(h≥0)的二叉树中至少有___个结点,至多有___个结点。 5.若用二叉链表来存储具有m个叶子,n个分支结点的树,则二叉链表中有___个左指针域为空的结点,有___个右指针域 为空的结点。 6.n个顶点的有根有向图中至少有___条边,至多有___条边。 7.10行20列矩阵若用行优先顺序表来表示,则矩阵中第8行第7列元素是顺序表中第___个元素。 8.在各元素查找概率相等的情况下,用顺序查找方法从含有12个元素的有序表中查找一个元素,元素间的平均比较次数是 _____。 9.在归并两个长度为m的有序表时,排序码的比较次数至少是___次,至多是___次。 10.在高度为3的6阶B-树中,至少有___个关键字,至多有___个关键字。 三、选择题(每题2分,共30分) 1.计算机所处理的数据一般具有某种内在联系性,这是指________。 A.元素和元素之间存在某种关系B.数据和数据之间存在某种关系 C.元素内部具有某种结构D.数据项和数据项之间存在某种关系 2. 假设顺序表目前有4个元素,第i个元素放在R[i]中,1≤i≤4 。若把新插入元素存入R[6],则________。 A.会产生运行错误B.R[1]~R[6]不构成一个顺序表 C.顺序表的长度大于顺序表元素个数,会降低存储空间利用率 D.顺序表元素序号和数组元素下标不一致,会给使用带来麻烦 3. 设H是不带表头结点循环单向链表的表头指针,P是和H同类型的变量。当P指向链表最后一个结点时,_________。A.P所指结点指针字段的值为空B.P的值与H的值相等 C.P所指结点的地址与H的值相等D.P所指结点指针字段的值与H的值相等 4. 栈的定义不涉及数据的__________。 A.逻辑结构B.存储结构C.运算D.逻辑结构和存储结构 5. 设5个元素进栈的顺序是1,2,3,4,5,则出栈的顺序有可能是___________。 A.2,4,1,3,5 B.3,4,1,5,2 C.3,2,4,1,5 D.4,1,3,2,5 6. 若某棵二叉树结点的前序序列和中序序列相同,则该二叉树_________。 A.只有一个结点B.每个结点都没有左孩子C.每个结点都没有右孩子D.不存在 7.对于一棵具有n个结点,度为3的树来说,____________。 A.树的高度至多是n-3 B.树的高度至多是n-2 C.树的最低高度是┏log3(n+1)┓ D.至少在某一层上正好有3个结点 8.n个顶点的有向图如果可以进行拓扑排序,则可以断定该有向图__________。 A.含n个强连通分量B.有唯一的入度为0的顶点C.有多个出度为0的顶点 D.是一个有根有向图 9. 特殊矩阵用行优先顺序表表示,_____________ A.简化了矩阵元素之间的逻辑关系B.便于按行处理矩阵元素

《数据结构》期末考试试题及答案

数据结构》期末考试试题及答案 ( 2003-2004 学年第 2 学期 ) 单项选择题 1、C 2、D 3、A 4、D 5、C 6、D 7、A 8、B 9、C 10、C 7.图的 Depth-First Search (DFS ) 遍历思想实际上是二叉树( 法的推广。 (A )、先序 ( B )、中序 (C )、后序 (D )、层序 8.在下列链队列 Q 中,元素 a 出队的操作序列为( p=Q.front->next; p->next= Q.front->next; p=Q.front->next; Q.front->next=p->next; p=Q.rear->next; p->next= Q.rear->next; p=Q->next; Q->next=p->next; 9. Huffman 树的带权路径长度 WPL 等于( c ( A )、除根结点之外的所有结点权值之和1.对于一个算法,当输入非法数据时,也要能作出相应的处理,这种要求称为 ( c )。 (A ) 、正确性 (B ). 可行性 (C ). 健壮性 2.设 S 为 C 语言的语句 ,计算机执行下面算法时, for (i=n-1 ; i>=0 ; i--) for (j=0 ;j

2017年数据结构期末考试题及答案A

2017年数据结构期末考试题及答案 一、选择题(共计50分,每题2分,共25题) 1 ?在数据结构中,从逻辑上可以把数据结构分为 C 。 A. 动态结构和静态结构B?紧凑结构和非紧凑结构 C.线性结构和非线性结构 D .内部结构和外部结构 2?数据结构在计算机内存中的表示是指 A ° A. 数据的存储结构 B.数据结构 C.数据的逻辑结构 D .数据元 素之间的关系 3.在数据结构中,与所使用的计算机无关的是数据的 A 结构。 A. 逻辑B?存储 C.逻辑和存储 D.物理 4 .在存储数据时,通常不仅要存储各数据元素的值,而且还要存储 C ° A.数据的处理方法B?数据元素的类型 C.数据元素之间的关系 D.数据的存储方法 5. 在决定选取何种存储结构时,一般不考虑 A ° A.各结点的值如何B?结点个数的多少 C?对数据有哪些运算 D.所用的编程语言实现这种结构是否方便。 6. 以下说法正确的是D ° A. 数据项是数据的基本单位 B. 数据元素是数据的最小单位 C. 数据结构是带结构的数据项的集合 D. —些表面上很不相同的数据可以有相同的逻辑结构 7. 在以下的叙述中,正确的是B ° A. 线性表的顺序存储结构优于链表存储结构 B. 二维数组是其数据元素为线性表的线性表 C?栈的操作方式是先进先出 D.队列的操作方式是先进后出

8. 通常要求同一逻辑结构中的所有数据元素具有相同的特性,这意味着 A. 数据元素具有同一特点 B. 不仅数据元素所包含的数据项的个数要相同,而且对应的数据项的类型要一致 C. 每个数据元素都一样 D. 数据元素所包含的数据项的个数要相等 9 ?链表不具备的特点是 A 。 A.可随机访问任一结点 B.插入删除不需要移动元素 C?不必事先估计存储空间 D.所需空间与其长度成正比 10. 若某表最常用的操作是在最后一个结点之后插入一个结点或删除最后一 个结点,则采用 D 存储方式最节省运算时间。 A.单链表B ?给出表头指针的单循环链表 C.双链表D ?带头结点 的双循环链表 11. 需要分配较大空间,插入和删除不需要移动元素的线性表,其存储结构是 B 。 A.单链表B .静态链表 C.线性链表 D .顺序存储结构 12 .非空的循环单链表head的尾结点(由p所指向)满足C 。 A. p—>next 一NULL B. p — NULL C. p—>next == head D. p = = head 13 .在循环双链表的p所指的结点之前插入s所指结点的操作是 D 。 A .p—> prior-> prior=s B .p—> prior-> n ext=s C.s —> prior—> n ext = s D.s —> prior—> prior = s 14 .栈和队列的共同点是C 。 A.都是先进后出 B .都是先进先出 C.只允许在端点处插入和删除元素 D .没有共同点

数据结构 期末考试复习题及答案

1.什么是最小生成树?简述最小生成树的Prime算法的思想。 答:最小生成树就是构造一棵生成树,使得树上各边的代价之和最小。 普里姆算法(Prim)的基本思想: 从连通网络N = { V, E }中的某一顶点u0 出发,选择与它关联的具有最小权值的边(u0, v),将其顶点加入到生成树的顶点集合U中。以后每一步从一个顶点在U中,而另一个顶点不在U中的各条边中选择权值最小的边(u, v),把它的顶点加入到集合U中。如此继续下去,直到网络中的所有顶点都加入到生成树顶点集合U中为止。 2.简述AOV网络中为何不能出现回路,如何判断AOV网络是否有回路? 答:在AOV网络中,如果活动vi必须在vj之前进行,则称为存在有向边;在AOV网络中不能出现有向回路,如果出现了,则意味着某项活动应以自己作为先决条件。 如何检查AOV网是否存在有向环: 检测有向环的一种方法是对AOV网络构造它的拓扑有序序列。即将各个顶点(代表各个活动)排列成一个线性有序的序列,使得AOV网络中所有应存在的前驱和后继关系都能得到满足。(1)这种构造AOV网络全部顶点的拓扑有序序列的运算就叫做拓扑排序。 (2)如果通过拓扑排序能将AOV网络的所有顶点都排入一个拓扑有序的序列中,则该AOV 网络中必定不会出现有向环;相反,如果得不到满足要求的拓扑有序序列,则说明AOV网络中存在有向环,此AOV网络所代表的工程是不可行的。

3.为何需要采用循环队列?n个空间的循环队列,最多存储多少个元素?为什 么? 答:循环队列以克服顺序队列的"假上溢"现象,能够使存储队列的向量空间得到充分的利用,所以采用循环队列。 n个空间的循环队列,最多存储n-1个元素,那是为了区别循环队列的队空和队满的条件。队空的条件是Q.front==Q.rear,而队满的条件是(Q.rear+1)%N==Q.front(N是数组中单元的总数),因此,Q.rear所指向的数组单元处于未用状态。所以说,N个单元的数组所存放的循环队列最大长度是N-1。 4.简述堆的删除算法,其删除的是那个值? 答:堆的删除算法:首先,移除根节点的元素(并把根节点作为当前结点)比较当前结点的两个孩子结点的元素大小,把较大的那个元素移给当前结点,接着把被移除元素的孩子结点作为当前结点,并再比较当前结点的孩子的大小,以此循环,直到最后一个叶子结点的值大于或等于当前结点的孩子结点或孩子结点的位置超过了树中元素的个数,则退出循环。最后把最后叶子结点的元素移给当前结点。 在堆的算法里面,删除的值为根值。 5.线索二叉树中,什么是线索,它是否唯一?可有根据什么顺序得到?

《数据结构C》模拟试题

山东科技大学继续教育学院 《数据结构C》模拟试题一 班级姓名学号 一、选择题(20分) 1. 组成数据的基本单位是( )。 (A) 数据项(B)数据类型(C)数据元素(D)数据变量 2. 线性表的链接实现有利于( )运算。 (A) 插入(B)读表元(C)查找(D)定位 3. 串的逻辑结构与( )的逻辑结构不同。 (A) 线性表(B)栈(C)队列(D)树 4. 二叉树第i(i≥1)层最多有( )个结点。 (A) 2i(B)2i (C) 2i-1(D) 2i-1 5. 设单链表中p指向结点A,若要删除A后结点(若存在),则需要修改p的操作为( ) (A) p.Next = p.Next.Next (B)p=p.Next (C)p=p.Next.Next (D)p.Next=p 6. 设一数列的输入顺序为1,2,3,4,5,6,通过栈操作不可能排成的输出序列为( ) (A) 3,2,5,6,4,1 (B) 1,5,4,6,2,3 (C) 2,4,3,5,1,6 (D) 4,5,3,6,2,1 7. 设字符串S1=’ABCDEFG’,S2=’PQRST’,则运算S=CONCAT(SUB(S1,2,LENGTH(S2)),SUB(S1,LENGTH(S2),2))的结果为( ) (A) ‘BCQR’ (B) ‘BCDEF’ (C) ’BCDEFG’ (D) ‘BCDEFEF’ 8. 有一个10阶的对称矩阵A,采用压缩存储方式,以行序为主存储,a11为第一元素,其存储地址为1,每个元素占1个地址空间,则a85地址为( ) (A)13 (B) 33 (C) 18 (D) 40 9. 如果结点A有3个兄弟,而且B为A的双亲,则B的度为( ) (A) 3 (B) 4 (C) 5 (D) 1 10. 线索化二叉树中某结点D没有左孩子的必要条件是( ) (A) D.Lchild=null (B) D.ltag=1 (C) D.Rchild=null (D) D.ltag=0 二、填空题(20分) 1. 对于一个以顺序实现的循环队列Q[0..m_1],队头、队尾指针分别为f,r,其判空的条件是 ,判满的条件是。 2. 循环链表的主要优点是。 3. 给定一个整数集合{3,5,6,9,12},画出其对应的一棵Huffman树。 4 双向循环链表中,在p所指的结点之后插入f所指的结点,其操作为。 5. 下列为朴素的模式匹配算法,请在算法的处填入正确的子句。

数据结构C语言版期末考试试题(有答案)

“数据结构”期末考试试题 一、单选题(每小题2分,共12分) 1.在一个单链表HL中,若要向表头插入一个由指针p指向的结点,则执行( )。 A. HL=ps p一>next=HL B. p一>next=HL;HL=p3 C. p一>next=Hl;p=HL; D. p一>next=HL一>next;HL一>next=p; 2.n个顶点的强连通图中至少含有( )。 A.n—l条有向边 B.n条有向边 C.n(n—1)/2条有向边 D.n(n一1)条有向边 3.从一棵二叉搜索树中查找一个元素时,其时间复杂度大致为( )。 A.O(1) B.O(n) C.O(1Ogzn) D.O(n2) 4.由权值分别为3,8,6,2,5的叶子结点生成一棵哈夫曼树,它的带权路径长度为( )。 A.24 B.48 C. 72 D. 53 5.当一个作为实际传递的对象占用的存储空间较大并可能需要修改时,应最好把它说明为( )参数,以节省参数值的传输时间和存储参数的空间。 A.整形 B.引用型 C.指针型 D.常值引用型· 6.向一个长度为n的顺序表中插人一个新元素的平均时间复杂度为( )。 A.O(n) B.O(1) C.O(n2) D.O(10g2n) 二、填空题(每空1分,共28分) 1.数据的存储结构被分为——、——、——和——四种。 2.在广义表的存储结构中,单元素结点与表元素结点有一个域对应不同,各自分别为——域和——域。 3.——中缀表达式 3十x*(2.4/5—6)所对应的后缀表达式为————。 4.在一棵高度为h的3叉树中,最多含有——结点。 5.假定一棵二叉树的结点数为18,则它的最小深度为——,最大深度为——· 6.在一棵二叉搜索树中,每个分支结点的左子树上所有结点的值一定——该结点的值,右子树上所有结点的值一定——该结点的值。 7.当向一个小根堆插入一个具有最小值的元素时,该元素需要逐层——调整,直到被调整到——位置为止。 8.表示图的三种存储结构为——、——和———。 9.对用邻接矩阵表示的具有n个顶点和e条边的图进行任一种遍历时,其时间复杂度为——,对用邻接表表示的图进行任一种遍历时,其时间复杂度为——。 10.从有序表(12,18,30,43,56,78,82,95)中依次二分查找43和56元素时,其查找长度分别为——和——· 11.假定对长度n=144的线性表进行索引顺序查找,并假定每个子表的长度均

《数据结构》期末考试题及答案

2011-2012学年第一学期期末考查 《数据结构》试卷 (答案一律写在答题纸上,在本试卷上做答无效) 一、选择(每题1分,共10分) 1.长度为n的线性表采用顺序存储结构,一个在其第i个位置插入新元素的算法时间复杂度为(D) A.O(0) B.O(1) C.O(n) D.O(n2) 2.六个元素按照6,5,4,3,2,1的顺序入栈,下列哪一个是合法的出栈序列?(D) A.543612 B.453126 C.346512 D.234156 3.设树的度为4,其中度为1、2、3、4的结点个数分别是4、2、1、2,则树中叶子个数为(B ) A.8 B.9 C.10 D.11 4.设森林F对应的二叉树B有m个结点,B的右子树结点个数为n,森林F中第一棵树的结点个数是( B ) A. m-n B.m-n-1 C.n+1 D.m+n 5.若一棵二叉树具有10个度为2的结点,5个度为1的结点,则度为0的结点个数是(B) A.9 B.11 C.15 D.不确定 6.下列哪一个方法可以判断出一个有向图是否有环。(A) A.深度优先遍历 B.拓扑排序 C.求最短路径 D.求关键路径 7.第7层有10个叶子结点的完全二叉树不可能有(B )个结点。 A.73 B.234 C.235 D.236 8.分别用以下序列构造二叉排序树,与用其他三个序列构造的结果不同的是(B) 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) 9.对一组数据(84,47,25,15,21)排序,数据的排列次序在排序过程中变化如下:(1)84 47 25 15 21 (2)15 47 25 84 21 (3)15 21 25 84 47(4)15 21 25 47 84则采用的排序方法是(B ) A.选择排序 B.起泡排序 C.快速排序 D.插入排序 10.对线性表进行折半查找时,要求线性表必须(D) A.以顺序方式存储 B.以顺序方式存储,且数据元素有序

《数据结构》模拟试卷一及答案

模拟试卷一 一、单选题(每题 2 分,共20分) 1.以下数据结构中哪一个是线性结构?( ) A. 有向图 B. 队列 C. 线索二叉树 D. B树 2.在一个单链表HL中,若要在当前由指针p指向的结点后面插入一个由q指向的结点, 则执行如下( )语句序列。 A. p=q; p->next=q; B. p->next=q; q->next=p; C. p->next=q->next; p=q; D. q->next=p->next; p->next=q; 3.以下哪一个不是队列的基本运算?() A. 在队列第i个元素之后插入一个元素 B. 从队头删除一个元素 C. 判断一个队列是否为空 D.读取队头元素的值 4.字符A、B、C依次进入一个栈,按出栈的先后顺序组成不同的字符串,至多可以组成 ( )个不同的字符串? A.14 B.5 C.6 D.8 5.由权值分别为3,8,6,2的叶子生成一棵哈夫曼树,它的带权路径长度为( )。 A. 11 B.35 C. 19 D. 53 图一 6.该二叉树结点的前序遍历的序列为( )。 A.E、G、F、A、C、D、B B. E、A、G、C、F、B、D C. E、A、C、B、D、G、F D. E、G、A、C、D、F、B 7.该二叉树结点的中序遍历的序列为( )。 A. A、B、C、D、E、G、F B. E、A、G、C、F、B、D C. E、A、C、B、D、G、F D. B、D、C、A、F、G、E 8.该二叉树的按层遍历的序列为( )。 A.E、G、F、A、C、D、B B. E、A、C、B、D、G、F C. E、A、G、C、F、B、D D. E、G、A、C、D、F、B 9.下面关于图的存储的叙述中正确的是( )。 A.用邻接表法存储图,占用的存储空间大小只与图中边数有关,而与结点个数无关B.用邻接表法存储图,占用的存储空间大小与图中边数和结点个数都有关 C. 用邻接矩阵法存储图,占用的存储空间大小与图中结点个数和边数都有关 D.用邻接矩阵法存储图,占用的存储空间大小只与图中边数有关,而与结点个数无关10.设有关键码序列(q,g,m,z,a,n,p,x,h),下面哪一个序列是从上述序列出发建 堆的结果?( )

数据结构期末考试试题及答案

《数据结构》期末考试试题及答案 (2003-2004学年第2学期) 单项选择题1、C 2、D 3、A 4、D 5、C 6、D 7、A 8、B 9、C 10、C 、 1. 对于一个算法,当输入非法数据时,也要能作出相应的处理,这种要求称为 (c )。 (A)、正确性但).可行性(C).健壮性 2 ?设S为C语言的语句,计算机执行下面算法时, for(i=n-1 ; i>=0; i--) for(j=0 ; jvi; j++) (A)、n2(B). O(nlgn) 3?折半查找法适用于( a (D). 输入性 算法的时间复杂度为(d S; (C). O(n) (D). )。 O(n2) (A)、有序顺序表(B)、有序单链表 (C)、有序顺序表和有序单链表都可以 4 .顺序存储结构的优势是( d )。 (A)、利于插入操作(B)、利于删除操作 (C)、利于顺序访问(D)、利于随机访问 5. 深度为k的完全二叉树,其叶子结点必在第 (A)、k-1 ( B)、k (C)、k-1 和 6. 具有60个结点的二叉树,其叶子结点有 (A)、11 ( B)、13 ( C)、48 (D)、无限制 c )层上。 (D)、1 至 k 12个,则度过1 (D)、37 k 的结点数为( 7 .图的Depth-First Search(DFS) 遍历思想实际上是二叉树( 法的推广。 (A)、先序(B)、中序(C)、后序(D)、层序 8.在下列链队列Q中,元素a出队的操作序列为( a )遍历方 front (A )、 (B )、 (C)、 (D )、p=Q.front->next; p->next= Q.front->next; p=Q.front->next; Q.front->next=p->next; p=Q.rear->next; p->next= Q.rear->next; p=Q->next; Q->next=p->next; 9. Huffman树的带权路径长度WPL等于( (A)、除根结点之外的所有结点权值之和(C)、各叶子结点的带权路径长度之和(B) 、 ) 所有结点权值之和 根结点的值 b ■

数据结构期末复习题

第一类题目选择题 1.从逻辑上可以把数据结构分为()两大类。 A.动态结构、静态结构 B.顺序结构、链式结构 C.线性结构、非线性结构 D.初等结构、构造型结构 2.若某线性表最常用的操作是存取任一指定序号的元素和在最后进行插入和删除运算,则利用()存储方式最节省时间。 A.顺序表 B.双链表 C.带头结点的双循环链表 D.单循环链表3.某线性表中最常用的操作是在最后一个元素之后插入一个元素和删除第一个元素,则采用()存储方式最节省运算时间。 A.单链表 B.仅有头指针的单循环链表 C.双链表 D.仅有尾指针的单循环链表 4.执行下面程序短的时间复杂度为()。 for(i=0;inext==NULL C. p==head D. p->next==head 8.某个栈的入栈序列是a,b,c,d,e,则可能的出栈序列是()。 A.a,d,b,e,c B.e,b,c,a,d C.b,c,d,e,a D.e,a,b,c,d 9. 有六个元素6,5,4,3,2,1 的顺序进栈,问下列哪一个不是合法的出栈序列?() A. 5 4 3 6 1 2 B. 4 5 3 1 2 6 C. 3 4 6 5 2 1 D. 2 3 4 1 5 6 10.二叉树的第I层上最多含有结点数为()。 A.2I B.2I-1 C.2I-1-1 D.2I-1 11. 如果从无向图的任一顶点出发进行一次深度优先搜索即可访问所有的顶点,则该图一定是()。 A.完全图 B.有回路 C.连通图 D.一棵树 12. 栈在()中应用。 A. 递归调用 B. 子程序调用 C. 表达式求值 D. A,B,C 13. 一个递归算法必须包括()。 A. 递归部分 B. 终止条件和递归部分 C. 迭代部分 D.终止条件和迭

数据结构模拟试卷(含答案)

数据结构设计课程代码:7399 一、单项选择题(在每小题列出的四个选项中只有一个选项是符合题目要求的,请将正确选项前的字母填在题后的括号内。每小题2分,共40分) 1、串的长度是()。 A、串中不同字母的个数 B、串中不同字符的个数 C、串中所含字符的个数,且大于0 D、串中所含字符的个数 2、若用数组S[1..n]作为两个栈S1和S2的共同存储结构,对任何一个栈,只有当S全满时才不能作入栈操作。为这两个栈分配空间的最佳方案是()。 A、S1的栈底位置为0,S2的栈底位置为n+1 B、S1的栈底位置为0,S2的栈底位置为n/2 C、S1的栈底位置为1,S2的栈底位置为n D、S1的栈底位置为1,S2的栈底位置为n/2 3、队列操作的原则是()。 A、先进先出 B、后进先出 C、只能进行插入 D、只能进行删除 4、有64个结点的完全二叉树的深度为()(根的层次为1)。 A、8 B、7 C、6 D、5 5、在有n个结点的二叉链表中,值为非空的链域的个数为()。

A、n-1 B、2n-1 C、n+1 D、2n+1 6、带权有向图G用邻接矩阵A存储,则顶点i的人度等于A中()。 A、第i行非∞的元素之和 B、第i列非∞的元素之和 C、第i行非∞且非0的元素个数 D、第i列非∞且非0的元素个数 7、在有n个结点且为完全二叉树的二叉排序树中查找一个键值,其平均比较次数的数量级为()。 A、0(n) B、0(log2n) C、0(nolg2n) D、0(n2) 8、若表R在排序前已按键值递增顺序排列,则()算法的比较次数最少。 A、直接插入排序 B、快速排序 C、归并排序 D、选择排序 9、下列排序算法中,()排序在某趟结束后不一定选出一个元素放到其最终的位置上。 A、选择 B、冒泡 C、归并 D、堆

数据结构考试题

一、选择题(共15题,每题2分,共计30分) 1、单链表的一个存储结点包含( C ) A.指针域和链域 B.指针域或链域 C.数据域或指针域 D.数据域和链域 2、采用线性链表表示一个向量时,要求占用的存储空间地址( D )。 A、必须是连续的 B、部分地址必须是连续的 C、一定是不连续的 D、可连续可不连续 3、当利用大小为n的数组顺序存储一个队列时,该队列的最大长度为( B )。 A. n-2 B. n-1 C. n D. n+1 4、在一个单链表中,若q结点是p结点的前驱结点,若在q与p之间插入结点s,则执行( D )。 A、s→next = p→next; p→next = s; B、p→next = s; s→next k = q; C、p→next = s→next; s→next = p; D、q→next = s; s→next = p; 5、在数组A中,每一个数组元素A[i, j] 占用3个存储字,行下标i从1到8,列下标j 从1到10。所有数组元素相继存放于一个连续的存储空间中,则存放该数组至少需要的存储字数是( C )。 A、 80 B、 100 C、 240 D、 270 6、将一个递归算法改为对应的非递归算法时,通常需要使用( A )。 A、栈 B、队列 C、循环队列 D、优先队列 7、一个队列的进队列顺序是1, 2, 3, 4,则出队列顺序为( C )。 A、4, 3, 2, 1 B、2, 4, 3, 1 C、1, 2, 3, 4 D、3, 2, 1, 4 8.下述各类表中可以随机访问的是(D )。 A. 单向链表 B. 双向链表 C.单向循环链表 D.顺序表 9.在一个长度为n的顺序表中为了删除第5个元素,从前到后依次移动了15个元素。则原顺序表的长度为( B )。 A. 21 B. 20 C. 19 D. 25 10.元素1,3,5按顺序依次进栈,则该栈的不可能的输出序列是( B )。 A. 5 3 1 B. 5 1 3 C. 3 1 5 D. 1 5 3 11.一个队列的入队序列是5,6,7,8,则队列的输出序列是( A )。 A. 5 6 7 8 B. 8 7 6 5 C. 7 8 6 5 D.可能有多种情况 12.在一个单链表中,p、q分别指向表中两个相邻的结点,且q所指结点是p所指结点的直接后继,现要删除q所指结点,可用语句(C )。 A.p=q->next B.p->next=q C.p->next=q->next D.q->next=NULL 13.设一棵哈夫曼树共有n个非叶结点,则该树一共有( B )个结点。 A. 2*n-1 B. 2*n +1 C. 2*n D. 2*(n-1) 14.对如图1所示二叉树进行中序遍历,结果是( A )。 A. dfebagc B. defbagc C. defbacg D.dbaefcg

2017数据结构期末考试试题及答案

2017《数据结构》期末考试试题及答案 《数据结构》期末考试试题及答案 1 ................................................................. 2..试题 1 答案............................................................ 7..《数据结构》期末考试试题及答案 2 ................................................................. 9..试题 2 答案........................................................................ 1.. 4. 《数据结构》期末考试试题及答案 3 ............................................................... 1..6试题 3 答案........................................................................ 2.. 1.

数据结构》期末考试试题及答案 1 单选题(每题 2 分,共 20 分) 1. 栈和队列的共同特点是 ( )。 A. 只允许在端点处插入和删除元素 B. 都是先进后出 C. 都是先进先出 D. 没有共同点 2. 用链接方式存储的队列,在进行插入运算时 ( ). A. 仅修改头指针 B. 头、尾指针都要修改 C. 仅修改尾指针 D .头、尾指针可能都要修改 3. 以下数据结构中哪一个是非线性结构? ( ) A. 队列 B. 栈 C. 线性表 D. 二叉树 4. 设有一个二维数组A[m][n],假设A[0][0]存放位置在644(io ), A[2][2]存放 若有18个元素的有序表存放在一维数组 A[19]中,第一个元素放A[1]中, 现进行二分查找,则查找 A [3]的比较序列的下标依次为( A. 1 , 2, 3 B. 9, 5, 2, 3 C. 9, 5, 3 D. 9, 4, 2, 3 8. 对n 个记录的文件进行快速排序,所需要的辅助存储空间大致为 A. O (1) B. O (n ) C. O ( 1 og 2n ) D. O (n2) 9. 对于线性表( 7, 34, 55, 25, 64, 46, 20, 10)进行散列存储时,若选 用 H (K )=K %9 作为散列函数,则散列地址为 1 的元素有( )个, 位置在 676(10),每个元素占一个空间, 表示用 10 进制表示。 问 A[3][3] (10)存放在什么位置?脚注 (10) 5. A .688 B .678 C . 692 D . 696 树最适合用来表示 ( )。 A.有序数据元素 B.无序数据元素 6. C.元素之间具有分支层次关系的数据 D .元素之间无联系的数据 二叉树的第 k 层的结点数最多为 ( ). A .2-1 B.2K+1 C.2K-1 D. 2k-1 7.

数据结构期末复习题

练习题: 一、填空题 1、元素项是数据的最小单位,数据元素是讨论数据结构时涉及的最小数据单位。 2、设一棵完全二叉树具有100个结点,则此完全二叉树有49个度为2的结点。 3、在用于表示有向图的邻接矩阵中,对第i列的元素进行累加,可得到第i个顶点的出度。 4、已知一棵度为3的树有2个度为1的结点,3个度为2的结点,4个度为3的结点,则该树中有12个叶子 的结点。 n=n0+n1+n2+…+nm (1) 又有除根结点外,树中其他结点都有双亲结点,且是唯一的(由树中的分支表示),所以,有双亲的结点数为:n-1=0*n0+1*n1+2*n2+…+m*nm (2) 联立(1)(2)方程组可得: 叶子数为:n0=1+0*n1+1*n2+2*n3+...+(m-1)*nm 5、有一个长度为20的有序表采用二分查找方法进行查找,共有4个元素的查找长度为3。 6、对于双向链表,在两个结点之间插入一个新结点需要修改的指针共4个。 删除一个结点需要修改的指针共2个。 7、已知广义表LS=(a,(b,c,d),e),它的深度是2,长度是3。 8、循环队列的引入是为了克服假溢出。 9、表达式a*(b+c)-d/f的后缀表达式是abc+*df/-。 10、数据结构中评价算法的两个重要指标是时间复杂度和空间复杂度。 11、设r指向单链表的最后一个结点,要在最后一个结点之后插入s所指的结点,需执行的三条语句是 r->next=s; r=s; r->next=null; 12、设有一个空栈,栈顶指针为1000H(十六进制),现有输入序列为1,2,3,4,5,经过 PUSH,PUSH,POP,PUSH,POP,PUSH,PUSH之后,输出序列是23,而栈顶指针值是1012_H。设栈为顺序栈,每个元素占4个字节。 13、模式串P=‘abaabcac’的next函数值序列为01122312。 14、任意连通图的连通分量只有一个,即是自身。 15、栈的特性是先进后出。 16、串的长度是包含的元素个数。 17、如果一个有向图中没有回路,则该图的全部顶点可能排成一个拓扑序列。 18、在具有n个叶子结点的哈夫曼树中,分支结点总数为n-1。176 19、在线性表的散列存储中,装填因子α又称为装填系数,若用m表示散列表的长度,n表示待散列存储的 元素的个数,则α等于n/m。 20、排序的主要目的是为了以后对已排序的数据元素进行查找。 21、对于一个具有n个结点的单链表,在已知的结点*p后插入一个新结点的时间复杂度为O(1),在给定值为 x的结点后插入一个新结点的时间复杂度为O(n)。 22、线性表L=(a1,a2,…,an)用数组表示,假定删除表中任一元素的概率相同,则删除一个元素平均需要 移动元素的个数是n/2。 23、两个栈共享空间时栈满的条件top1=top2-1。 24、深度为H 的完全二叉树至少有H个结点;至多有2^H-1个结点;H和结点总数N之间的关系是 H=[log2n]+1。150 25、在有序表A[1…20]中,按二分查找方法进行查找,查找长度为4的元素的下标从小到大依次是1 3 6 8 11 13 16 19 26、设查找表中有100个元素,如果用二分法查找方法查找数据元素X,则最多需要比较7次就可以断定数 据元素X是否在查找表中。

相关文档
最新文档