版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、要求:所有的题目的解答均写在答题纸上,需写清楚题目的序号。每张答题纸都要写上姓名和学号。一、单项选择题(每小题1.5分,20小题,共计30分)1. 以下数据结构中 属非线性结构。A.栈B.串C.队列D.平衡二叉树2. 以下算法的时间复杂度为 。void func(int n)int i=0,s=0;while (s<=n)i+;s=s+i;A. O(n)B. O()C. O(nlog2n)D. O(log2n)3. 在一个双链表中,删除p所指节点(非首、尾节点)的操作是 。A.p->prior->next=p->next;p->next->prior=p-&
2、gt;prior;B.p->prior=p->prior->prior;p->prior->prior=p;C.p->next->prior=p;p->next=p->next->next;D.p->next=p->prior->prior;p->prior=p->prior->prior;4. 设n个元素进栈序列是1、2、3、n,其输出序列是p1、p2、pn,若p1=3,则p2的值为 。A.一定是2B.一定是1C.不可能是1D.以上都不对5. 在数据处理过程中常需要保存一些中间数据,如果要实现先保
3、存的数据先处理,则应采用 来保存这些数据。A.线性表B.栈C.队列D.单链表6. 中缀表达式a*(b+c)-d的对应的后缀表达式是 。A.a b c d * + -B.a b c +* d -C.a b c * + d -D.- + * a b c d7. 设栈s和队列q的初始状态都为空,元素a、b、c、d、e和f依次通过栈s,一个元素出栈后即进入队列q,若6个元素出队的序列是b、d、c、f、e、a,则栈s的容量至少应该存多少个元素?A.2B.3C.4D.58. 设循环队列中数组的下标是0N-1,其队头队尾指针分别为f和r(f指向队首元素的前一位置,r指向队尾元素),则其元素个数为 。A.r-
4、fB.r-f-1C.(r-f)N+1D.(r-f+N)N9. 若将n阶上三角矩阵A按列优先顺序压缩存放在一维数组B1.n(n+1)/2中,A中第一个非零元素a1,1存于B数组的b1中,则应存放到bk中的非零元素ai,j(1jn,1ij)的下标i、j与k的对应关系是 。A. i(i+1)/2+jB. i(i-1)/2+jC. j(j+1)/2+iD. j(j-1)/2+i10. 一棵节点个数为n高度为h的m(m3)次树中,其分支数是 。A.nhB.n+mC.n-1D.h-111. 设森林F对应的二叉树为B,B中有m个节点,其根节点的右子树的节点个数为n,森林F中第一棵树的节点个数是 。A.m-n
5、B.m-n-1C.n+1D. 条件不足,无法确定12. 一棵二叉树的先序遍历序列为ABCDEF,中序遍历序列为CBAEDF,则后序遍历序列为 。A.CBEFDAB.FEDCBAC.CBEDFAD.不确定13. 在一个具有n个顶点的有向图中,构成强连通图时至少有 条边。A.nB.n+lC.n-1D.n/214. 对于有n个顶点的带权连通图,它的最小生成树是指图中任意一个 。A.由n-1条权值最小的边构成的子图B.由n-l条权值之和最小的边构成的子图C.由n-l条权值之和最小的边构成的连通子图D.由n个顶点构成的极小连通子图,且边的权值之和最小15. 对于有n个顶点e条边的有向图,采用邻接矩阵表示
6、,求单源最短路径的Dijkstra算法的时间复杂度为 。A.O(n)B.O(n+e)C.O(n2)D.O(ne)16. 一棵高度为h的平衡二叉树,其中每个非叶子节点的平衡因子均为0,则该树的节点个数是 。A.2h-1-1B.2h-1C.2h-1+1D.2h-117. 对线性表进行折半查找时,要求线性表必须 。A.以顺序方式存储B.以链接方式存储C.以顺序方式存储,且节点按关键字有序排序D.以链表方式存储,且节点按关键字有序排序18. 假设有k个关键字互为同义词,若用线性探测法把这k个关键字存入哈希表中,至少要进行 次探测。A.k-1B.kC.k+1D.k(k+1)/219. 以下排序算法中,某
7、一趟排序结束后未必能选出一个元素放在其最终位置上的是 。A.堆排序B.冒泡排序C.直接插入排序D.快速排序20. 以下排序方法中, 不需要进行关键字的比较。A.快速排序B.归并排序C.基数排序D.堆排序二、问答题(共4小题,每小题10分,共计40分)1. 已知一棵度为m的树中有n1个度为1的节点,n2个度为2的节点,nm个度为m的节点,问该树中有多少个叶子节点?(需要给出推导过程)2. 设关键字集合D=1,12,5,8,3,10,7,13,9,试完成下列各题:(1)依次取D中各关键字,构造一棵二叉排序树bt;(2)如何依据此二叉树bt得到D的一个关键字递增序列;(3)画出在二叉树bt中删除12
8、后的树结构。3. 一个有n(n>10)个整数的数组R1.n,其中所有元素是有序的,将其看成是一棵完全二叉树,该树构成一个堆吗?若不是,请给一个反例;若是,请简要说明理由。4. 若要在N个海量数据(超过十亿,不能一次全部放入内存)中找出最大的k个数(内存可以容纳k个数),最好采用什么数据结构和策略?请详细说明你采用的数据结构和策略,并用时间复杂度和空间复杂度来说明理由。三、算法设计题(共3小题,每小题10分,共计30分)1. 设A=(a1,a2,an),B=(b1,b2,bm)是两个递增有序的线性表(其中n、m均大于1),且所有数据元素均不相同。假设A、B均采用带头节点的单链表存放,设计一
9、个尽可能高效的算法判断B是否为A的一个连续子序列,并分析你设计的算法的时间复杂度和空间复杂度。(10分)2. 假设二叉树b采用二叉链存储结构存储,试设计一个算法,求该二叉树中从根节点出发的一条最长的路径长度,并输出此路径上各节点的值。(10分)3. 假设一个无向图是非连通的,采用邻接表作为存储结构,试设计一个算法,输出图中各连通分量的节点序列。(10分)“数据结构”考试试题(A)参考答案要求:所有的题目的解答均写在答题纸上,需写清楚题目的序号。每张答题纸都要写上姓名和学号。一、单项选择题(每小题1.5分,共计30分)1. D2. B3. A4. C5. C6. B7. B8. D9. D10.
10、 C11. A12. A13. A14. D15. C16. D17. C18. D19. C20. C二、问答题(共3小题,每小题10分,共计30分)1. 解:依题意,设n为总的节点个数,n0为叶子节点(即度为0的节点)的个数,则有:n=n0+n1+n2+nm又有:n-1=度的总数,即,n-1=n1×1+n2×2+nm×m两式相减得:1=n0-n2-2n3-(m-1)nm则有:n0=1+n2+2n3+(m-1)nm=。2. 答:(1)本题构造的二叉排序树如图10.20所示。(2)D的有序序列为bt的中序遍历次序,即:1、3、5、7、8、9、10、12、13。(3
11、)为了删除节点12,找到其左子树中的最大节点10(其双亲节点为8),将该节点删除并用10代替12,删除后的树结构如图10.21所示。图10.20 一棵二叉排序树 图10.21 删除12后的二叉排序树3. 答:该数组一定构成一个堆,递增有序数组构成一个小根堆,递减有序数组构成一个大根堆。以递增有序数组为例,假设数组元素为k1、k2、kn是递增有序的,从中看出下标越大的元素值也越大,对于任一元素ki,有ki<k2i,ki<k2i+1(i<n/2),这正好满足小根堆的特性,所以构成一个小根堆。3. 有一棵二叉排序树按先序遍历得到的序列为:(12,5,2,8,6,10,16,15,1
12、8,20)。回答以下问题:(1)画出该二叉排序树。(2)给出该二叉排序树的中序遍历序列。(3)求在等概率下的查找成功和不成功情况下的平均查找长度。4. 首先读入k个数,假设第一次读取的k个数就是前k个最大的数,然后把k个数建成小顶堆。然后从第k+1个数开始,每个数都与堆顶的数值进行比较,如果数字d大于堆顶元素,则把堆顶的元素的元素替换成d,再将其调整成为小顶堆。当所有数据都读入并比较完之后,这个小顶堆里面的所有元素就是最大的k个数。时间复杂度为O(NlogK),空间复杂度为O(K)。三、算法设计题(共计40分)1.(15分)解:采用二路归并思路,用p、q分别扫描有序单链表A、B,先找到第一个两
13、者值相等的节点,然后在两者值相等时同步后移,如果B扫描完毕返回1,否则返回0。对应的算法如下:int SubSeq(LinkList *A,LinkList *B)LinkList *p=A->next,*q=B->next;while (p!=NULL && q!=NULL)/找两个单链表中第一个值相同的节点if (p->data<q->data)p=p->next;else if (p->data>q->data)q=q->next;elsebreak;while (p!=NULL && q!=NU
14、LL && p->data=q->data)/当两者值相等时同步后移p=p->next;q=q->next;if (q=NULL)/当B中节点比较完毕返回1return 1;else/否则返回0return 0;本算法的时间复杂度为O(m+n),空间复杂度为O(1)。其中m、n分别为A、B单链表的长度。2.(15分)解:由于二叉树中最长路径一定是从根节点到某个叶子节点的路径,可以求出所有叶子节点到根节点的逆路径,通过比较长度得出最长路径,可以采用多种解法。算法中用形参maxpath数组存放最长路径,maxpathlen存放最长路径长度。解法1:对应的算法
15、如下:void MaxPath(BTNode *b,ElemType maxpath,int &maxpathlen)/maxpathlen的初值为0struct snodeBTNode *node;/存放当前节点指针int parent;/存放双亲节点在队列中的位置 QuMaxSize;/定义非循环队列ElemType pathMaxSize;/存放一条路径int pathlen;/存放一条路径长度int front,rear,p,i;/定义队头和队尾指针front=rear=-1;/置队列为空队列rear+;Qurear.node=b;/根节点指针进进队Qurear.parent=
16、-1;/根节点没有双亲节点while (front<rear)/队列不为空front+;b=Qufront.node;/队头出队列if (b->lchild=NULL && b->rchild=NULL)/*b为叶子节点p=front;pathlen=0;while (Qup.parent!=-1)pathpathlen=Qup.node->data;pathlen+;p=Qup.parent;pathpathlen=Qup.node->data;pathlen+;if (pathlen>maxpathlen)/通过比较求最长路径for (i
17、=0;i<pathlen;i+)maxpathi=pathi;maxpathlen=pathlen;if (b->lchild!=NULL)/左孩子节点进队rear+;Qurear.node=b->lchild;Qurear.parent=front;if (b->rchild!=NULL)/右孩子节点进队rear+;Qurear.node=b->rchild;Qurear.parent=front;本算法的时间复杂度为O(n),空间复杂度为O(n)。解法2:对应的算法如下:void MaxPath1(BTNode *b,ElemType path,int pat
18、hlen,ElemType maxpath,int &maxpathlen)/pathlen和maxpathlen的初值均为0int i;if (b=NULL)if (pathlen>maxpathlen)/通过比较求最长路径for (i=pathlen-1;i>=0;i-)maxpathi=pathi;maxpathlen=pathlen;elsepathpathlen=b->data;/将当前节点放入路径中pathlen+;/路径长度增1MaxPath1(b->lchild,path,pathlen,maxpath,maxpathlen);/递归扫描左子树M
19、axPath1(b->rchild,path,pathlen,maxpath,maxpathlen);/递归扫描右子树本算法的时间复杂度为O(n),空间复杂度为O(n)。解法3:对应的算法如下:void MaxPath2(BTNode *b,ElemType maxpath,int &maxpathlen)/maxpathlen的初值为0BTNode *StMaxSize;BTNode *p;ElemType pathMaxSize;/存放一条路径int pathlen;/存放一条路径长度int i,flag,top=-1;/栈顶指针置初值if (b!=NULL)dowhile (b!=NULL)/将*b的所有左节点进栈top+;Sttop=b;b=b->lchild;p=NULL;/p指向栈顶节点的前一个已访问的节点flag=1;/设置b的访问标记为已访问过while (top!=-1 && flag)b=Sttop;/取出当前的栈顶元素if (b->rchild=p)/右孩子不存在或右孩子已被访问,访问之if (b->lchild=NULL && b->rchild=NULL) /*b为叶子节
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 办公环境中的老人关怀措施
- 企业责任与青少年视力保护
- 城市生活中的孕妇营养与健康饮食策略
- 2025中国联通上海市分公司春季校园招聘30人高频重点提升(共500题)附带答案详解
- 2025中国电子信息产业发展研究院春季招聘高频重点提升(共500题)附带答案详解
- 2025中国二冶集团春季校园招聘400人高频重点提升(共500题)附带答案详解
- 2025下半年辽宁事业单位招聘同步考试考务工作高频重点提升(共500题)附带答案详解
- 2025下半年福建柘荣县事业单位招聘人员历年高频重点提升(共500题)附带答案详解
- 2025下半年浙江省舟山定海区财政局招聘编外人员3人历年高频重点提升(共500题)附带答案详解
- 2025下半年广东省清远佛冈县招聘事业单位人员243人笔试高频重点提升(共500题)附带答案详解
- 2024年1月浙江省普通高校招生选考科目考试思想政治试题(含答案)
- 造纸行业岗位安全操作规程
- 律师事务所人员管理制度
- 带封面的新员工入职登记表
- 20以内的加法口算练习题4000题 205
- 玻璃打胶记录
- 《全媒体营销与运营(微课版)》-教学大纲
- Module3 Unit2 Do they like apples?(教学设计)-2024-2025学年外研版(一起)英语二年级上册
- 医院教学工作汇报
- 篮球球星姚明课件
- 2024-2030年中国计算机视觉行业市场发展趋势与前景展望战略分析报告
评论
0/150
提交评论