数据结构自学考试试题+答案.docx
- 文档编号:8035475
- 上传时间:2023-01-28
- 格式:DOCX
- 页数:11
- 大小:183.06KB
数据结构自学考试试题+答案.docx
《数据结构自学考试试题+答案.docx》由会员分享,可在线阅读,更多相关《数据结构自学考试试题+答案.docx(11页珍藏版)》请在冰豆网上搜索。
数据结构自学考试试题+答案
2019年4月高等教育自学考试全国统一命题考试
数据结构
(课程代码02331)
第一部分选择题
一、单项选择题:
本大题共15小题,每小题2分,共30分。
在每小题列出的备选项中只有一项是最符合题目要求的,请将其选出。
1.线性表是一种由n个数据元素组成的数据结构,n的取值是
A.0或者任意一个正整数或者∞B.非负整数
C.任意一个正整数或者∞D.某个正整数
2.在一个单链表中,已知q所指结点是p所指结点的后继结点,若在p和q之间插入s所指结点,则正确的操作是
A.s->next=p->next;p->next=s;B.s->next=q;p->next-s->next;
C.q->next=s;s->next-p;D.p->next=s;s->next=p;
3.下列选项中,不宜通过栈求解的问题是
A.判断字符串是否是回文B.检验圆括号是否匹配
C.不同数制之间进行转换D.图的广度优先搜索遍历
4.设栈S的输入序列为1,2,3,4,5,则下列选项中不可能是s的输出序列的是
A.2,3,4,1,5B.5,4,1,3,2C.2,3,1,4,5D.1,5,4,3,2
5.使用一个大小为6的数组保存循环队列Q。
若从Q中出队两个元素,并入队个元素,此时队尾rear和队头front的值分别为2和4.则在执行这三个操作之前rear和font的值分别是
A.0和3B.1和2C.2和5D.4和5
6.设二维数组M有3行4列,按行优先的方式存储,每个元素占6个存储单元。
第1个元素的存储地址为100,则M[2][2]的存储地址为
A.135B.153C.160D.165
7.设n阶方阵M是对称矩阵,采用压缩存储方式将M中的元素保存在一维数组B中,则下列选项中,正确的是
A.保存M中的主对角线中的元素,B的元素个数是n
B.保存M中上三角部分的元素,B的元素个数是n(n-1)/2
C.保存M中上三角部分的元素,B的元素个数是n(n+1)2
D.保存M中的全部元素,B的元素个数是
8.已知完全二叉树T的第4层有5个叶结点,则T的结点个数最多是
A.12B.20C.21D.36
9.在一棵非空二叉树的后序遍历序列中,所有列在根结点前面的是
A.左子树中的部分结点B.右子树中的全部结点
C.左右子树中的部分结点D.左右子树中的全部结点
10.若对题10图所示的无向图进行深度优先搜索遍历,则下列选项中正确的遍历序列是
A.h,c,a,b,d,e,g,fB.e,a,f,g,b,h,c,d
C.d,b,c,a,h,e,f,gD.a,b,c,d,h,e,f,g
11.对题11图所示的有向图进行拓扑排序。
下列选项中能够得到的拓扑序列是
A.3,1,2,4,5,6B.3,1,2,4,6,5
C.3,1.4.2,5,6D.3,1,4,2,6,5
12.已知数据序列(8,9,10,4,5,6,20,1,2)是某种排序算法第-趟排序后得到的结果,则该算法可能是
A.选择排序B.起泡排序C.直接插入排序D.快速排序
13.下列选项中,每一趟都能选出一个元素放在其最终位置上,且不稳定的排序算法是
A.起泡排序B.希尔排序C.归并排序D.快速排序
14.对有序表(1,9,12,41,62,77,82,95,100)采用二分查找方法查找值82,查找过程中关键字的比较次数是
A.1B.2C.4D.7
15.将下列数据依次插入到初始为空的二叉排序树中,能得到高度最小的二叉排序树的序列是
A.2,4,7,5,8,10B.5,1,2,6,3,4C.6,4,1,8,10,5D.9.7.2.1.4.0
第二部分非选择题
二、填空题:
本大题共10小题,每小题2分,共20分。
16.线性表的存储方式中,能够随机存取表中任一元素的存储结构是。
17.用S表示入栈操作,X表示出栈操作,若元素入栈顺序为1234,为了得到1342的出栈顺序,相应的S.X操作串为。
18.若广义表L的深度是∞,则L一定是。
19.广义表((a,b),(c,d),e)的表尾是。
20.利用二叉树中的空指针域,使之指向结点在某种遍历次序下的前趋或后继结点,此时域中的内容称为。
21.若用n个带权字符构造哈夫曼树T,则T中结点的总数是。
22.设连通带权图G中有n个顶点,使用普里姆算法构造G的最小生成树T,T中含有的边数是。
23.要使n个记录的关键字序列k1,k2,...,kn成为小根堆,关键字之间必须满足的关系是。
24.索引顺序查找是一种将顺序查找和二分查找思想结合在一起的查找方法,又称为。
25.5阶B树T中,除根结点之外每个结点中所含关键字个数最少是。
三.解答题:
本大题共4小题,每小题5分,共20分。
26.设细数矩阵M如下所示。
矩阵的行列下标均从1开始,请画出M按行优先存储的三元组表。
27.已知二叉树T的前序遍历序列是A,B,C,D,E,L,M,O,N,中序遍序列是C,B,E,D,A,M,O,L,N,请画出T。
28.已知有向带权图G如题28图所示。
请回答下列问题。
(1)给出图G的邻接矩阵。
(2)求出G中从源点A到其余各顶点的最短路径。
要求根据迪杰斯特拉算法的求解过程依次给出各条路径,包括路径上经过的顶点及其长度。
29.设有关键字序列(65,23,31,26,7,91,53,15,72,52),散列函数为H(key)=key%11,将关键字依次放入表长为11的散列表H中,采用线性探测法处理冲突。
请回答下列问题。
(1)画出构造的散列表,并给出查找每个关键字的探查次数。
(2)求散列表的平均查找长ASL。
四、算法阅读题:
本大题共4小题,每小题5分,共20分。
30.顺序表类型定义如下:
#defineListSize100
typedefstruct{
intdata[ListSize];
intlength;
}SeqList;
阅读下列算法,并回答问题。
voidmysum(SeqList*SL1,SeqList*SL2)
{intminlength,k=0;
minlength=SL2->length;
for(k=0;k if(SLI->data[k] elseSL2->data[k]+=SLI->data[k]; return; } voidf30(SeqList*SL1,SeqList*SL2) {if(SL1->length>SL2->length)mysum(SLI,SL2); elsemysum(SL2,SLI); return; } (1)若SL1->data中的数据为(2,14,256,9,-38,30,128,257,64),SL2->data中的数据为(32,14,63,15,29,51,16,8),则执行算法f30(&SL1,&SL2)后SL1->data和SL2->data中的数据各是什么? (2)该算法的功能是什么? 31.二叉树的存储结构类型定义如下: typedef int DataType; typedef struct node { DataType data;//data是数据域 struct node*lchild, * rchild;//分别指向左右孩子 }BinTNode; typedef BinTNode * BinTree; 阅读下列算法,并回答问题。 int height( BinTreeT) { int lhigh = 0, rhigh= 0; if(T == NULL) retum 0; else{ lhigh = height( T>lchild); rhigh = height( T>rchild); if( Ihigh> rhigh) returm lhigh+1; else retum rhigh+1; } } Voidf31(BinTreeT) { intleftHigh=0,rightHigh=0; BinTreetemp; if(T==NULL)return; else{ if(height(T->lchild) temp=T->lchild; T->lchild=T->rchild; T->rchild=temp; } } f31(T->lchild); f31(T->rchild); return; } (1)设二叉树T如题31图所示,画出执行f31(T)后得到的二叉树T1。 (2)给出函数f31()的功能。 32.设顺序表的存储类型定义如下: # defineListSize 100 typedef int KeyType; typedef struct { KeyType key; }NodeType; typedefNodeType SeqLis([ListSize]; 函数f32()的功能是,基于二分查找在长度为n的有序表R中插入一个关键字x,并 保持R的有序性。 请在空白处填上适当语句使算法正确。 void 32( SeqList R,KeyTypex,intn) { int low=0, high=n-1,mid,inspace,ifind=0; while(low<=high&&! find ){ mid=(low+high)/2; if(x (1); elseif(x>R[mid].key)low=mid+l; elsefind=l; } if(find) inspace= (2); else inspace=low; for(i=n;(3);i--) R[i+1]=R[i]; R[inspace].key=x; } 34.设顺序表的存储类型定义如下: typedef int KeyType; typedef struct { KeyType key; }RecType; 阅读下列算法,并回答问题。 int f33(RecTypeR[],inti,intj) { RecType x = R[D]; while(i while(i if(i R(ij.key = R[j].key; i++; } while(i if(i R[j].key= R([].key;j-; } } R[i].key = x.key; return i; } (1)设ReType R[]={52,14,256,-9,-38,30,128,258,64},给出执行f33(R,0,8)后R的结果。 (2)给出该算法的功能。 五、算法设计题: 本题10分。 34.已知二叉树的存储结构类型定义如下: typedefstructnode { int data; struct node*lchild,*rchild; }BinNode; typedef BinNode *BinTree; 编写递归算法,对于给定的一棵二叉树T,计算并返回所有结点data域的值之和。 函数原型为: intf4(BinTreeT);。 例如,对于题34图所示的二叉树T,f34(T)应返回24. 2019年4月高等教育自学考试全国统一命题考试 数据结构试题答案及评分参考 (课程代码02331) 一、单项选择题: 本大题共5小题,每小题2分,共30分。 1.B2.A3.D4.B5.B6.C7.C8.C9.D10.D11.D12.C13.D14.B15.C 二填空题: 本大题共10小题,每小题2分,共20分。 16.顺序存储结构17.SXSSXSXX 18.递表19.((c.d).c) 20.线索21.2n-1 22.n-123.k,k,1k,≤ky1(1≤i≤ ) 24.分块查找25.2 三、解答题: 本大题共4小题,每小题5分,共20分。 26.(5分) i j v 0 1 2 -8 1 1 4 6 2 2 1 7 3 3 1 -5 4 3 5 3 【评分说明】每个非零元素的行、列及值正确,且次序也正确,给1分。 部分正确酌情给分。 27.(5分) 28. (1)G的邻接矩阵(1分) (2)根据地杰斯特拉算法求得的各条最短路径依次是(4分) 次序 最短路径 长度 1 AE 2 2 AC 3 3 ACB 4 4 ACD 5 【评分说明】每条最短路径上所含的顶点、路径长度正确,且次序正确,给1分。 部分正酌情给分。 29. (1)散列表及各关键字的探查次数(4分) 0 1 2 3 4 5 6 7 8 9 10 53 23 91 26 15 72 7 52 31 65 3 1 1 1 2 1 1 1 1 1 下标(地址) 散列表 探查次数 【评分说明】散列表的内容部分,共给3分,探查次数部分,共给1分。 部分正确酌情给分。 (2)ASL=(3+1+1+1+2+1+1+1+1+1)/10=1.3(1分) 四、算法阅读题: 本大题共4小题,每小题5分,共20分。 30.(I)SL1->data中的数据是(52,14,256,6,-9,81,128,257,64)(2分) SL2->data中的数据是(84,28,193,15,29,51,144,265)(2分) (2)该算法比较两个线性表中相同下标位置的两个元素(以较短者为限),将两者之和放到原来较小者的位置,若原来两者相等,则将两者之和放到SL2中。 (1分) 31. (1)(4分) (2)函数f13( )的功能是: 将二叉树T的每个结点的高度较高的子树放到左子树位置,高度较矮的子树放到右子树位置。 (1分) 32. (1)high=mid-1(2分) (2)mid(1分) (3)i>=inspace(2分) 33. (1)R中的值是{30,14,-38,-9,52,256,128,258,64}。 (4分) (2)该算法选择第一个元素作为基准,实现对数组的一次划分。 (或实现快速排序的一次划分。 )(1分) 五、算法设计题: 本题10分。 34.参考程序如下。 int f34 (BinTree T) { int leftSum=0,rightSum=0;(1分) if(T==NULL)returm 0;(2分) else { if(T->Ichild! =NULL)leftSum=f34(T>lchild);(3分) if(T->rchild! =NULL)rightSum=f34(T->rchild);(3分) return leftSum+rightSum+T->data;(1分) } }
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据结构 自学考试 试题 答案