秋国家开放大学《数据结构本》期末练习1100分答案16年秋.docx
- 文档编号:4950511
- 上传时间:2022-12-12
- 格式:DOCX
- 页数:11
- 大小:18.95KB
秋国家开放大学《数据结构本》期末练习1100分答案16年秋.docx
《秋国家开放大学《数据结构本》期末练习1100分答案16年秋.docx》由会员分享,可在线阅读,更多相关《秋国家开放大学《数据结构本》期末练习1100分答案16年秋.docx(11页珍藏版)》请在冰豆网上搜索。
秋国家开放大学《数据结构本》期末练习1100分答案16年秋
2016秋国家开放大学《数据结构(本)》期末练习1
一、单项选择题
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.在对一组记录(55,39,97,22,16,73,65,47,88)进行直接插入排序时,当把第7个记录65
插入到有序表时,为寻找插入位置需比较_________次。
24.有以下程序段
chara[]=“English”;
char*p=a;intn=0;
while(*p!
=‘\0’){n++;p++;}结果中,n的值是_______。
三、综合题
1.设查找表为(1,10,11,14,23,27,29,55,68),元素的下标依次为1,2,3,……,9。
(1)画出对上述查找表进行折半查找所对应的判定树(树中结点用下标表示)。
(2)说明成功查找到元素14,需要依次经过与哪些元素的比较?
共几次比较?
(3)求在等概率条件下,成功查找的平均比较次数?
.
2.有一个长度为11的有序表(1,2,11,15,24,28,30,56,69,70,80),元素的下标依次为
1,2,3,……,11,按折半查找对该表进行查找。
(1)画出对上述查找表进行折半查找所对应的判定树。
(2)说出成功查找到元素56,,需要依次经过与哪些元素的比较?
(3)说出不成功查找元素72,需要进行元素比较的次数?
3.
(1)以3,4,5,8,9,作为叶结点的权,构造一棵哈夫曼树。
(2)给出相应权重值叶结点的哈夫曼编码。
(3)n个叶结点的哈夫曼树,总共有多少个结点?
4.
(1)一组记录的关键字序列为(57,90,67,50,51,56),利用堆排序(堆顶元素是最小元素)的方法建立初始堆(要求以完全二叉树描述)。
(2)对关键字序列(56,51,71,54,46,106)利用快速排序,以第一个关键字为分割元素,
给出经过一次划分后结果。
(3)一组记录的关键字序列为(60,47,80,57,39,41,46,30),利用归并排序的方法,分别给出(1,1)归并、(2,2)归并、(4,4)归并的结果序列。
四、程序填空题
1.以下是中序遍历二叉树的递归算法的程序,完成程序中空格部分(树结构中左、
右指针域分别为left和right,数据域data为字符型,BT指向根结点)。
voidInorder(structBTreeNode*BT)
{
if(BT!
=NULL){
(1);
(2);
Inorder(BT->right);}
}
利用上述程序对右图进行遍历,结果是(3);
2.设线性表为(16,20,26,24),以不带头结点的单向链表存储,链表头指针为head,以下程序的功能是输出链表中各结点中的数据域data。
structnode
{intdata;
structnode*next;
};
typedefstructnodeNODE;
#defineNULL0
voidmain()
{NODE*head,*p;
p=head;/*p为工作指针*/
do
{printf(“%d\n”,___
(1)_____);
___
(2)_____;
}while(___(3)_____);
}
3.以下冒泡法程序对存放在a[1],a[2],……,a[n]中的序列进行排序,完成程序中的空格部分,其中n是元素个数,要求按升序排列。
voidbsort(NODEa[],intn)
{NODEtemp;
inti,j,flag;
for(j=1;
(1);j++);
{flag=0;
for(i=1;
(2);i++)
if(a[i].key>a[i+1].key)
{flag=1;
temp=a[i];
(3);
(4);
}
if(flag==0)break;
}
}
设有序列6,4,5,8,2,1,给出由该程序经过两趟冒泡后的结果序列(5)
4.以下函数为直接选择排序算法,对a[1],a[2],…a[n]中的记录进行直接选择排序,完成
程序中的空格
typedefstruct
{intkey;
……
}NODE;
voidselsort(NODEa[],intn)
{
inti,j,k;
NODEtemp;
for(i=1;i<=___
(1)_____;i++)
{
k=i;
for(j=i+1;j<=
(2)_____;j++)
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据结构本 国家 开放 大学 数据结构 期末 练习 1100 答案 16 年秋