数据结构与算法模拟试卷一、二及参考答案.doc

上传人:scccc 文档编号:10976783 上传时间:2021-06-14 格式:DOC 页数:9 大小:326.50KB
返回 下载 相关 举报
数据结构与算法模拟试卷一、二及参考答案.doc_第1页
第1页 / 共9页
数据结构与算法模拟试卷一、二及参考答案.doc_第2页
第2页 / 共9页
数据结构与算法模拟试卷一、二及参考答案.doc_第3页
第3页 / 共9页
数据结构与算法模拟试卷一、二及参考答案.doc_第4页
第4页 / 共9页
数据结构与算法模拟试卷一、二及参考答案.doc_第5页
第5页 / 共9页
点击查看更多>>
资源描述

《数据结构与算法模拟试卷一、二及参考答案.doc》由会员分享,可在线阅读,更多相关《数据结构与算法模拟试卷一、二及参考答案.doc(9页珍藏版)》请在三一文库上搜索。

1、四川大学数据结构与算法分析课程考试模拟试卷 模拟试卷一一、 单选题(每题 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.

2、判断一个队列是否为空 D.读取队头元素的值4. 字符A、B、C依次进入一个栈,按出栈的先后顺序组成不同的字符串,至多可以组成( )个不同的字符串? A.14 B.5 C.6 D.85. 由权值分别为3,8,6,2的叶子生成一棵哈夫曼树,它的带权路径长度为( )。EAGCBDF图1A 11 B.35 C. 19 D. 53以下6-8题基于图1。6. 该二叉树结点的前序遍历的序列为( )。A. E、G、F、A、C、D、B B. E、A、G、C、F、B、DC. E、A、C、B、D、G、F D. E、G、A、C、D、F、B7. 该二叉树结点的中序遍历的序列为( )。A. A、B、C、D、E、G、FB.

3、 E、A、G、C、F、B、D C. E、A、C、B、D、G、F E. B、D、C、A、F、G、E 8. 该二叉树的按层遍历的序列为( )。 AE、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、B9. 下面关于图的存储的叙述中正确的是( )。 A用邻接表法存储图,占用的存储空间大小只与图中边数有关,而与结点个数无关 B用邻接表法存储图,占用的存储空间大小与图中边数和结点个数都有关 C. 用邻接矩阵法存储图,占用的存储空间大小与图中结点个数和边数都有关 D用邻接矩阵法存储图,占用的存储空间大小只与图中边数有关,而与结点个数

4、无关10. 设有关键码序列(q,g,m,z,a,n,p,x,h),下面哪一个序列是从上述序列出发建堆的结果?( ) A. a,g,h,m,n,p,q,x,z B. a,g,m,h,q,n,p,x,z C. g,m,q,a,n,p,x,h,z D. h,g,m,p,a,n,q,x,z二、 填空题(每空1分,共26分)1. 数据的物理结构被分为_、_、_和_四种。2. 对于一个长度为n的顺序存储的线性表,在表头插入元素的时间复杂度为_,在表尾插入元素的时间复杂度为_。3. 向一个由HS指向的链栈中插入一个结点时p时,需要执行的操作是_;删除一个结点时,需要执行的操作是_(假设栈不空而且无需回收被删

5、除结点)。4. 对于一棵具有n个结点的二叉树,一个结点的编号为i(1in),若它有左孩子则左孩子结点的编号为_,若它有右孩子,则右孩子结点的编号为_,若它有双亲,则双亲结点的编号为_。5. 当向一个大根堆插入一个具有最大值的元素时,需要逐层_调整,直到被调整到_位置为止。6. 以二分查找方法从长度为10的有序表中查找一个元素时,平均查找长度为_。7. 表示图的三种常用的存储结构为_、_和_。8. 对于线性表(70,34,55,23,65,41,20)进行散列存储时,若选用H(K)=K %7作为散列函数,则散列地址为0的元素有_个,散列地址为6的有_个。9. 在归并排序中,进行每趟归并的时间复杂

6、度为_,整个排序过程的时间复杂度为_,空间复杂度为_。10. 在一棵m阶B_树上,每个非树根结点的关键字数目最少为_个,最多为_个,其子树数目最少为_,最多为_。三、 运算题(每题 6 分,共24分)图21. 写出下列中缀表达式的后缀形式:(1) 3X/(Y-2)+1(2) 2+X*(Y+3)2. 试对图2中的二叉树画出其:(1) 顺序存储表示的示意图;(2) 二叉链表存储表示的示意图。3. 判断以下序列是否是小根堆? 如果不是, 将它调整为小根堆。(1) 12, 70, 33, 65, 24, 56, 48, 92, 86, 33 (2) 05, 23, 20, 28, 40, 38, 29

7、, 61, 35, 76, 47, 100 4. 已知一个图的顶点集V和边集E分别为: V=1,2,3,4,5,6,7; E=(1,2)3,(1,3)5,(1,4)8,(2,5)10,(2,3)6,(3,4)15,(3,5)12,(3,6)9,(4,6)4, (4,7)20,(5,6)18,(6,7)25; 按照普里姆算法从顶点1出发得到最小生成树,试写出在最小生成树中依次得到的各条边。四、 阅读算法(每题7分,共14分)1. void AE(Stack& S) InitStack(S); Push(S,3); Push(S,4); int x=Pop(S)+2*Pop(S); Push(S,

8、x); int i,a5=1,5,8,12,15; for(i=0;i5;i+) Push(S,2*ai); while(!StackEmpty(S) coutPop(S)left,c1,c2); c1+; if (BT-left=NULL&BT-right=NULL) c2+; ABC(BT-right,c1,c2); /if 该函数执行的功能是什么?五、 算法填空(共8分)向单链表的末尾添加一个元素的算法。Void InsertRear(LNode*& HL,const ElemType& item)LNode* newptr;newptr=new LNode;If (_)cerrMemo

9、ry allocation failare!next=NULL;if (HL=NULL) HL=_;elseLNode* P=HL;While (P-next!=NULL) _;p-next=newptr; 六、 编写算法(共8分)编写从类型为List的线性表L中将第i个元素删除的算法,(假定不需要对i的值进行有效性检查,也不用判别L是否为空表。) void Delete(List& L, int i)模拟试卷一参考答案一、 单选题(每题2分,共20分)1.B 2.D 3.A 4.B 5.B 6.C 7.A 8.C 9.B 10.B二、 填空题(每空1分,共26分)1. 顺序 链表 索引 散列

10、2. O(n) O(1)3. p-next=HS;HS=p HS=HS-next4. 2i 2i+1 i/2(或i/2)图35. 向上 根6. 2.97. 邻接矩阵 邻接表 边集数组8. 1 49. O(n) O(nlog2n) O(n)10. m/2-1 m-1 m/2 m 三、 运算题(每题6分,共24分)1. (1) 3 X * Y 2 - / 1 + (2) 2 X Y 3 + * + 2. (1)012345678910111213141516123456789 (2)见图3所示: 3. (1)不是小根堆。调整为:12,65,33,70,24,56,48,92,86,33 (2)是小

11、根堆。 4. 普里姆算法从顶点1出发得到最小生成树为:(1,2)3, (1,3)5, (1,4)8, (4,6)4, (2,5)10, (4,7)20四、 阅读算法(每题7分,共14分)1. 30 24 16 10 2 102. 该函数的功能是:统计出BT所指向的二叉树的结点总数和叶子总数 五、 算法填空(共8分,每一空2分)newptr=NULL newptr-=data newptr p=p-next六、 编写算法(8分) void Delete(List& L, int i) for(int j=i-1;jnext=HL; B. p-next=HL-next; HL-next=p; C.

12、 p-next=HL; p=HL; D. p-next=HL; HL=p; 2. 若顺序存储的循环队列的QueueMaxSize=n,则该队列最多可存储( )个元素. A. n B.n-1 C. n+1 D.不确定3. 下述哪一条是顺序存储方式的优点?( ) A存储密度大 B.插入和删除运算方便 C. 获取符合某种条件的元素方便 D.查找运算速度快4. 设有一个二维数组Amn,假设A00存放位置在600(10),A33存放位置在678(10),每个元素占一个空间,问A23(10)存放在什么位置?(脚注(10)表示用10进制表示,m3) A658 B648 C633 D6535. 下列关于二叉树

13、遍历的叙述中,正确的是( ) 。A. 若一个树叶是某二叉树的中序遍历的最后一个结点,则它必是该二叉树的前序遍历最后一个结点B若一个点是某二叉树的前序遍历最后一个结点,则它必是该二叉树的中序遍历的最后一个结点 C若一个结点是某二叉树的中序遍历的最后一个结点,则它必是该二叉树的前序最后一个结点 D若一个树叶是某二叉树的前序最后一个结点,则它必是该二叉树的中序遍历最后一个结点6. k层二叉树的结点总数最多为( ). A2k-1 B.2K+1 C.2K-1 D. 2k-17. 对线性表进行二分法查找,其前提条件是( ).A. 线性表以链接方式存储,并且按关键码值排好序 B. 线性表以顺序方式存储,并且

14、按关键码值的检索频率排好序C. 线性表以顺序方式存储,并且按关键码值排好序D. 线性表以链接方式存储,并且按关键码值的检索频率排好序8. 对n个记录进行堆排序,所需要的辅助存储空间为 A. O(1og2n) B. O(n) C. O(1) D. O(n2)9. 对于线性表(7,34,77,25,64,49,20,14)进行散列存储时,若选用H(K)=K %7作为散列函数,则散列地址为0的元素有( )个, A1 B2 C3 D410. 下列关于数据结构的叙述中,正确的是( ).A. 数组是不同类型值的集合 B. 递归算法的程序结构比迭代算法的程序结构更为精炼C. 树是一种线性结构D. 用一维数组

15、存储一棵完全二叉树是有效的存储方法二、 填空题(每空1分,共26分)1. 数据的逻辑结构被分为_、_、_和_四种。2. 一个算法的时间复杂度为(3n3+2000nlog2n+90)/n2,其数量级表示为_。3. 对于一个长度为n的单链存储的队列,在表头插入元素的时间复杂度为_,在表尾插入元素的时间复杂度为_。4. 假定一棵树的广义表表示为A(D(E,G),H(I,J),则树中所含的结点数为_个,树的深度为_,树的度为_。5. 后缀算式79 2 30 + - 4 2 / *的值为_。中缀算式(3+X*Y)-2Y/3对应的后缀算式为_。6. 在一棵高度为5的理想平衡树中,最少含有_个结点,最多含有

16、_个结点。7. 在树中,一个结点的直接后继结点称为该结点的_。一个结点的直接前趋结点称为该结点的_。8. 在一个具有10个顶点的无向完全图中,包含有_条边,在一个具有n个顶点的有向完全图中,包含有_条边。9. 假定一个线性表为(12,17,74,5,63,49,82,36),若按Key % 4条件进行划分,使得同一余数的元素成为一个子表,则得到的四个子表分别为_、_、_和_。10. 对一棵B_树进行删除元素的过程中,若最终引起树根结点的合并时,会使新树的高度比原树的高度_。11. 在堆排序的过程中,对任一分支结点进行筛运算的时间复杂度为_,整个堆排序过程的时间复杂度为_。12. 在线性表的散列

17、存储中,装填因子a又称为装填系数,若用m表示散列表的长度,n表示待散列存储的元素的个数,则a等于_。三、 运算题(每题 6 分,共24分)1 在如下数组A中链接存储了一个线性表,表头指针存放在A 0.next,试写出该线性表。 A 0 1 2 3 4 5 6 7 data605078903440next40527132 已知一棵二叉树的前序遍历的结果是ABKCDFGHIJ, 中序遍历的结果是KBCDAFHIGJ, 试画出这棵二叉树。3 已知一个图的顶点集V为: V=1,2,3,4,5,6,7; 其共有10条边。该图用如下边集数组存储:起点1225522613终点6454767775权11222

18、33457试用克鲁斯卡尔算法依次求出该图的最小生成树中所得到的各条边及权值。4 画出向小根堆中加入数据4, 2, 5, 8, 3, 6, 10, 1时,每加入一个数据后堆的变化。四、 阅读算法(每题7分,共14分)1. 在下面的每个程序段中,假定线性表La的类型为List,元素类型ElemType为int,并假定每个程序段是连续执行的。试写出每个程序段执行后所得到的线性表La。(1) InitList(La); Int a=100,26,57,34,79; For (i=0;i5;i+) Insert(La,ai); TraverseList(La);(2) DeleteFront(La);I

19、nsertRear(La, DeleteFront(La); TraverseList(La);(3) ClearList(La); For (i=0;i5;i+) InsertFront(La,ai); TraverseList(La);2. 现面算法的功能是什么?void ABC(BTNode * BT) if BT coutdataleft); ABC(BT-right); 五、 算法填空(共8分)二分查找的递归算法。 Int Binsch(ElemType A,int low,int high,KeyType K) if _ int mid=(low+high)/2; if (_) r

20、eturn mid; /查找成功,返回元素的下标 else if (KAmid.key) return Binsch(A,low,mid-1,K); /在左子表上继续查找 else return_; /在右子表上继续查找 else _; /查找失败,返回-1 六、 编写算法(共8分)HL为单链表的表头指针,试写出在该单链表中查找具有给定的元素item的算法。bool Find(LNode* HL, ElemType &item)模拟试卷二参考答案一、 单选题(每题2分,共20分)1.B 2.B 3.A 4.C 5.D 6.A 7.C 8.C 9.D 10.D二、 填空题(每空1分,共26分)1

21、. 集合结构 线性结构 树结构 图结构2. O(n)3. O(1) O(1)4. 7 2 25. 94 3 X Y * + 2 Y * 3 / -6. 16 317. 孩子(或子)结点 双亲(或父)结点8. 45 n(n-1)9. (12,36) (17,5,49) (74,82) (63)10. 减少1(或减少)11. O(log2n) O(nlog2n)12. n/m三、 运算题(每题6分,共24分)1. 线性表为:(90,40,78,50,34,60)2. 当前序序列为ABKCDFGHIJ,中序序列为KBCDAFHIGJ时,逐步形成二叉树的过程如下图4所示: AAAAFBBFFBGKCG

22、KCHIGJCDKFHIGJHDJHIJDIKBCD图43. 用克鲁斯卡尔算法得到的最小生成树为: (1,6)1, (2,4)1, (2,5)2, (5,7)2, (2,6)3, (3,5)74. 见图5。222444555244423881222253553351064310486484868图5四、 阅读算法(每题7分,共14分)1. (1) La=(26,34,57,79,100) (2)La=(57,79,100,34) (3)La=(79,34,57,26,100) 2. 前序遍历链式存储的二叉树。五、 算法填空(每空2分,共8 分)(lowdata=item) return true; else p=p-next; return false;9

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 社会民生


经营许可证编号:宁ICP备18001539号-1