浙大远程教育数据结构与算法离线作业参考答案

整理文档很辛苦,赏杯茶钱您下走!

免费阅读已结束,点击下载阅读编辑剩下 ...

阅读已结束,您可以下载文档离线阅读编辑

资源描述

1浙江大学远程教育学院《数据结构与算法》课程离线作业姓名:学号:年级:学习中心:—————————————————————————————一、填空题:(【序号,章,节】。。。。。。)【1,1,2】线性结构中元素之间存在一对一关系,树形结构中元素之间存在一对多关系,图形结构中元素之间存在多对多关系。【2,1,2】为了最快地存取数据元素,物理结构宜采用顺序存储结构。【3,1,2】存储结构可根据数据元素在机器中的位置是否一定连续分为顺序存储结构,链式存储结构。【4,1,3】度量算法效率可通过时间复杂度来进行。【5,1,3】设n为正整数,下面程序段中前置以记号@的语句的频度是n(n+1)/2。for(i=0;in;i++){for(j=0;jn;j++)if(i+j==n-1)@a[i][j]=0;}【6,1,3】设n为正整数,试确定下列各程序段中前置以记号@的语句的频度:(1)i=1;k=0;while(i=n-1){i++;@k+=10*i;//语句的频度是n-1。}(2)k=0;for(i=1;i=n;i++){for(j=i;j=n;j++)@k++;//语句的频度是n(n+1)/2。2}【7,3,2】线性表(a1,a2,…,an)有两种存储结构:顺序存储结构和链式存储结构,请就这两种存储结构完成下列填充:顺序存储密度较大;顺序存储利用率较高;顺序可以随机存取;链式不可以随机存取;链式插入和删除操作比较方便。【8,3,2】从一个长度为n的顺序表中删除第i个元素(1≤i≤n)时,需向前移动n-i个元素。【9,3,2】带头结点的单链表Head为空的条件是Head-next=NULL。【10,3,2】在一个单链表中p所指结点(p所指不是最后结点)之后插入一个由指针s所指结点,应执行s-next=_p-next;和p-next=s的操作。【11,3,2】在一个单链表中删除p所指结点时,应执行以下操作:q=p-next;p-data=p-next-data;p-next=p-next-next;free(q);【12,3,2】带头结点的单循环链表Head的判空条件是Head-next==Head;不带头结点的单循环链表的判空条件是Head==NULL。【13,3,2】已知L是带表头结点的非空单链表,且P结点既然不首元结点,也不是尾元结点,试从下列提供的答案中选择合适的语句序列。a.删除P结点的直接前驱结点的语句序列是1012811414。b.删除结点P的语句序列是10127314。c.删除尾元结点的语句序列是911314。(1)P=P-next;(2)P-next=P;(3)P-next=P-next-next;(4)P=P-next-next;(5)while(P!=NULL)P=P-next;(6)while(Q-next!=NULL){P=Q;Q=Q-next};(7)while(P-next!=Q)P=P-next;(8)while(P-next-next!=Q)P=P-next;(9)while(P-next-next!=NULL)P=P-next;(10)Q=P;(11)Q=P-next;(12)P=L;3(13)L=L-next;(14)free(Q);【14,3,3】对一个栈,给定输入的顺序是A、B、C,则全部不可能的输出序列有CAB。【15,3,3】.在栈顶指针为HS的链栈中,判定栈空的条件是head-next==NULL。【16,3,3】下列程序把十进制数转换为十六进制数,请填写合适的语句成分。voidconversion10_16(){InitStack(&s);scanf(“%d”,&N);while(N){Push(s,N%16);N=N/16;}while(!StackEmpty(s)){Pop(s,e);if(e=9)printf(“%d”,e);elseprintf(“%c”,e-10+’A’);}}/*conversion*/【17,3,4】若用一个大小为6个元素的数组来实现循环队列,且当前rear=0和front=3。当从队列中删除一个元素,再加入两个元素后,rear和front的值分别是2和4。【18,3,4】堆栈和队列都是线性表,堆栈是后进先出的线性表,而队列是先进先出的线性表。【19,3,4】若用一个大小为6个元素的数组来实现循环队列,且当前rear=0和front=3。当从队列中删除一个元素,再加入两个元素后,rear和front的值分别是2和4。【20,4,2】已知一棵树边的集合是{a,d,d,c,d,j,e,a,f,g,d,b,g,h,g,i,e,f}。那么根结点是e,结点b的双亲是d,结点a的子孙有bcdj,树的深度是4,树的度是3,结点g在树的第3层。【21,4,3】从概念上讲,树与二叉树是二种不同的数据结构,将树转化为二叉树的基本的目的是采用二叉树的存储结构并利用二叉树的已有算法解决树的有关问题。【22,4,3】满三叉树的第i层的结点个数为3i-1,深度为h时该树中共有3h-1结点。【23,4,3】已知一棵完全二叉树有56个叶子结点,从上到下、从左到右对它的结点进行编号,根结点4为1号。则该完全二叉树总共结点有111个;有7层;第91号结点的双亲结点是45号;第63号结点的左孩子结点是32号。【24,4,3】下列表示的图中,共有5个是树;有3个是二叉树;有2个是完全二叉树。【25,4,4】n个结点的二叉排序树的最大深度是n,最小深度为[log2n]+1。【26,4,3】如果某二叉树的后序遍历序列是ABCDEFGHI,中序遍历序列是ACBIDFEHG,则其先序遍历序列的第一个字母是I,最后一个字母是G。【27,4,3】下列二叉树的中序遍历序列是DBNGOAEC;后序遍历序列是DNIGBECA。5【28,5,4】设HASH表的大小为n(n=10),HASH函数为h(x)=x%7,如果二次探测再散列方法Hi=(H(key)+di)mod10(di=12,22,32,…,)解决冲突,在HASH表中依次插入关键字{1,14,55,20,84,27}以后,关键字1、20和27所在地址的下标分别是1、7和5。插入上述6个元素的平均比较次数是2。【29,6,3】设无权图G的邻接矩阵为A,若(vi,vj)属于图G的边集合,则对应元素A[i][j]等于1,22、设无向图G的邻接矩阵为A,若A[i][j]等于0,则A[j][i]等于0。【30,6,3】若一个图用邻接矩阵表示,则删除从第i个顶点出发的所有边的方法是矩阵第i行全部置为零。【31,6,2】设一个图G={V,{A}},V={a,b,c,d,e,f},A={a,b,b,e,a,e,c,a,e,d,d,f,f,c}。那么顶点e的入度是2;出度是1;通过顶点f的简单回路有2条;就连通性而言,该图是强连通图;它的强连通分量有1个;其生成树可能的最大深度是5。【32,7,1】排序过程一般需经过两个基本操作,它们是比较和移动。【33,7,2】在对一组关键字是(54,38,96,45,15,72,60,23,83)的记录进行直接插入排序时,当把第七个记录(关键字是60)插入到有序表时,为寻找插入位置需比较3次。【34,7,4】插入排序、希尔排序、选择排序、快速排序、堆排序、归并排序、和基数排序方法中,不稳定的排序方法有希尔排序、快速排序、堆排序。6二、综合题(选自教材《数据结构》各章习题,采用word文件格式上传)【1,1,3】试分析下面一段代码的时间复杂度:if(AB){for(i=0;iN;i++)for(j=N*N;ji;j--)A+=B;}else{for(i=0;iN*2;i++)for(j=N*2;ji;j--)A+=B;}答:ifAB为真,则for语句的外循环N次,内循环为N(N-1)次,因此时间复杂度为O(N*N(N-1)),也就是N的三次方。ifAB为假,则for语句的外循环2N次,内循环为N次,因此时间复杂度为O(2N*N),也就是N的平方。整段取最大的,时间复杂度就是N立方。【2,1,3】测试例1.3中秦九韶算法与直接法的效率差别。令ixxfii/1)(1001,计算)1.1(f的值。利用clock()函数得到两种算法在同一机器上的运行时间。答:直接法:0.1μs秦九韶算法:0.04μs【3,1,3】试分析最大子列和算法1.3的空间复杂度。答:算法1.3的基本思路是将原问题拆分成若干小型问题,分别解决后再将结果合而治之,用递归方法实7现。算法1.3的负责度分析略有难度:若记整体时间复杂度为T(N),则函数DivideAndConquer中通过递归实现“分”的复杂度为2T(N/2),因为我们解决了2个长度减半的字问题。求跨分界线的最大子列和时,有两个简单的for循环,所用步骤一共不超过N,所以可以在O(N)时间完成。其他步骤都只需常熟O(1)时间。综上分析则有递推式:T(1)=O(1);T(N)=2T(N/2)+O(N)=2[2T((N/2)/2+O(N/2)]+O(N)=22T(N/22)+2O(N)=…=2KT(N/2k)+kO(N)当不断对分直到N/2k=1,即2k=N时,就得到T(N)=NT(1)+logN*O(N)=O(NlogN)。此算法比算法1.2又快了一些,当N=104时,效果会非常明显。但是这仍然不是最快的算法。【4,1,3】试给出判断N是否为质数的)(NO的算法。答:intsushu(intN){inti;intflag=1;if(N==1)returnfalse;//1既不是合数也不是质数if(N==2)returntruefor(i=2;i=sqrt(N);i++){if(N%i==0)8{flag=0;break;}}returnflag;}【5,2,2】请编写程序,输入整数n和a,输出S=a+aa+aaa+…+aa…a(n个a)的结果。答:#includestdio.hintmain(){inta,b,n,i,s=0;scanf(%d%d,&a,&n);b=a;for(i=1;i=n;i++){s+=a;a=a*10+b;}printf(%d\n,s);}【6,2,3】请编写递归函数,输出123..n的全排列(n小于10),并观察n逐步增大时程序的运行时间。9答:#includestdio.h#defineN8intn=0;voidswap(int*a,int*b){intm;m=*a;*a=*b;*b=m;}voidperm(intlist[],intk,intm){inti;if(km){for(i=0;i=m;i++)printf(%d,list[i]);printf(\n);n++;10}else{for(i=k;i=m;i++){swap(&list[k],&list[i]);perm(list,k+1,m);swap(&list[k],&list[i]);}}}intmain(){intlist[N];intnum,i=0;printf(Pleaseinputanum:);scanf(%d,&num);while(num!=0){list[i]=num%10;11num=num/10;i++;}perm(list,0,i-1);printf(total:%d\n,n);return0;}【7,3,2】给定一个顺序存储的线性表L=(1a,2a,,na),请设计一个算法删除所有值大于min而且小于max的元素。答:#includestdio.h#includestdlib.h#includemath.htypedefintElemType;typedefstructLNode{ElemTypedata;/*数据子域*/structLNode*next;/*指针子域*/}LNode;/*结点结构类型*

1 / 32
下载文档,编辑使用

©2015-2020 m.777doc.com 三七文档.

备案号:鲁ICP备2024069028号-1 客服联系 QQ:2149211541

×
保存成功