2017年电大本科《数据结构(本)》期末复习试题及答案
一、单项选择题
1.栈和队列的共同特点是()。
A.元素都可以随机进出B.都是先进先出 C.都是先进后出D.都是操作受限的线性结构 2.数据的存储结构包括数据元素的表示和()。 A.数据处理的方法B.数据元素间的关系的表示 C.相关算法D.数据元素的类型
3.对一个栈顶指针为top的链栈进行入栈操作,通过指针变量p生成入栈结点,则执行:p=(structnode*)malloc(sizeof(structnode);p->data=a;和()。 A.top->next=p;p=top;B.p->nex=top;top=p; C.top=top->next;p=top;D.p->next=top;p=top;
4.树状结构中数据元素的位置之间存在()的关系。
A.每一个元素都有一个直接前驱和一个直接后继B.一对一 C.多对多D.一对多
5.设头指针为head的非空的单向链表,指针p指向尾结点,则通过以下操作() 可使其成为单向循环链表。 A.p->next=NULL;B.head=p; C.p->next=head;D.p=head;
6.设有一个长度为26的顺序表,要插入一个元素,并使它成为新表的第6个元素,需 移动元素的个数为()。 A.21B.22C.20D.19 7.一种逻辑结构()。
A.只能有唯一的存储结构B.可以有不同的存储结构
C.与存储该逻辑结构的计算机相关D.是指某一种数据元素的性质
8.头指针为head的带头结点的单向循环链表,p所指向尾结点,要使该链表成为 不带头结点的单向循环链表,可执行head=head->nex;和()。 A.p=head->nextB.head->next=p
C.head->next=p->nextD.p->next=head;
9.把数据存储到计算机中,并具体体现数据元素间的逻辑结构称为()。 A.存储结构B.逻辑结构
C.数据元素的存储D.给数据元素分配存储空间
10.元素111,113,115,117按顺序依次进栈,则该栈的不可能输出序列是()(进 栈出栈可以交替进行)。
A.117,115,113,111B.111,113,115,117 C.117,115,111,113D.113,111,117,115
11.图状结构中数据元素的位置之间存在()的关系。 A.一对一B.一对多
C.多对多D.每一个元素都有一个且只有一个直接前驱和一个直接后继 12.以下说法正确的是()。 A.栈的特点是先进先出 B.栈的特点是先进后出
C.队列的特点是先进后出
D.栈和队列的特点都是后进后出
13.一个单链表中,在p所指结点之后插入一个s所指的结点时,可执行: s->next=p->next;和()。
A.s=p->next;B.p->next=s->next; C.p=s->next;D.p->next=s;
14.设有一个20阶的对称矩阵A(第一个元素为a1,1),采用压缩存储的方式,将其下三 角部分以行序为主序存储到一维数组B中(数组下标从1开始),则矩阵元素a6,2 在一维数组B中的下标是()。 A.21B.28C.17D.23
15.元素12,14,16,18顺序依次进栈,则该栈的不可能输出序列是()。 (进栈出栈可以交替进行)。
A.18,16,14,12B.12,14,16,18 D.14,12,18,16D.18,16,12,14 16.设有串p1=”ABADF”,P2=”ABAFD”,P3=”ABADFA”,P4=”ABAF”,以下四个串中最大的是()。
A.p3B.p2C.p1D.p4
17.设有一个30阶的对称矩阵A(第一个元素为a1,1),采用压缩存储的方式,将其 下三角部分以行序为主序存储到一维数组B中(数组下标从1开始),则矩阵中元 素a9,2在一维数组B中的下标是()。 A.41B.32C.18D.38
18.数组a经初始化chara[]=“English”;a[7]中存放的是()。 A.字符串的结束符B.字符h C.〝h〞D.变量h
19.设有一个长度为32的顺序表,要删除第8个元素需移动元素的个数为()。 A.15B.22C.14D.24
20.设主串为“ABcCDABcdEFaBc”,以下模式串能与主串成功匹配的是()。 A.BcdB.BCdC.ABCD.Abc
21.在一棵二叉树中,若编号为i的结点存在右孩子,则右孩子的顺序编号为()。 A.2iB.2i-1C.2i+1D.2i+2
22.在一棵二叉树中,若编号为i的结点存在左孩子,则左孩子的顺序编号为()。 A.2i+1B.2i-1C.2iD.2i+2
23.一棵具有16个结点的完全二叉树,共有()层。(设根结点在第一层) A.7B.6C.4D.5
24.如图1所示,若从顶点a出发,按图的广度优先搜索法进行遍历,则可能得 到的一种顶点序列为()。
A.abecdfB.aebcfdC.aecbdfD.aedfcb
25.如图2所示,若从顶点a出发,按图的深度优先搜索法进行遍历,则可能得 到的一种顶点序列为()。
A.abecdfgB.acfebgdC.aebcfgdD.aedfcgb
26.线性表以()方式存储,能进行折半查找。 A.链接B.顺序C.关键字有序的顺序D.二叉树
27.字符串“DABcdabcd321ABC”的子串是()。 A.“cd32”B.“ABcD” C.“aBcd”D.“321a”
28.一棵具有38个结点的完全二叉树,最后一层有()个结点。 A.7B.5C.6D.8
29.如图3所示,若从顶点a出发,按广度优先搜索法进行遍历,则可 能得到的一种顶点序列为()。
A.abcdfgeB.abcdfegC.acbfedgD.abcfgde
30.下图4的拓扑序列是()。 A.52346B.23645 C.56234D.23564
二、填空题
1.对稀疏矩阵进行压缩存储,可采用三元组表,一个有10行的稀疏矩阵A共有97个 零元素,其相应的三元组表共有3个元素。该矩阵A有列。 2.结构中的数据元素存在多对多的关系称为________结构。
3.在单向链表中,q指向p所指结点的直接后继结点,要删除q所指结点,可以用 操作______=q->next;。
4.n个元素进行冒泡法排序,第j趟冒泡要进行______次元素间的比较。
5.对稀疏矩阵进行压缩存储,矩阵中每个非零元素对应的三元组包括该元素的行下标、列下标和_______三项信息。
6.中序遍历________树可得到一个有序序列。 7.队列的操作特点是后进________。
8.待排序的序列为8,3,4,1,2,5,9,采用直接选择排序算法,当进行了两趟选择后,结果序列为()。 9.n个元素进行冒泡法排序,通常需要进行________趟冒泡。 10广义表((a,b),d,e,((i,j),k))的长度是________。
11.中序遍历二叉排序树可得到一个________的序列。 12.广义表的(c,a,(a,b),d,e,((i,j),k))深度是________。 13.广义表(c,a,(a,b),d,e,((i,j),k))的长度是________。
14.对稀疏矩阵进行压缩存储,可采用三元组表,一个有10行10列的稀疏矩阵A共有95个零元素,其相应的三元组表共有个元素。
15.广义表的(c,a,(a,b),d,e,((i,j),k))深度是________。
16.在对一组记录(50,49,97,22,16,73,65,47,88)进行直接插入排序时,当把第7个记录65插入到有序表时,为寻找插入位置需比较_________次。
17.循环队列在规定少用一个存储空间的情况下,队空的判定条件为________。 18.一棵有5个叶结点的哈夫曼树,该树中总共有_____个结点。 19.c语言中,字符串“E”存储时占个字节。
20.设有一棵深度为4的完全二叉树,第四层上有5个结点,该树共有_______个结点。 (根所在结点为第1层)。
21.一棵二叉树中有n个非叶结点,每一个非叶结点的度数都为2,则该树共有_______ 个叶结点。
22.设有一个长度为40的顺序表,要删除第8个元素需移动元素的个数为_______。23.在