数据结构与算法离线作业

上传人:小** 文档编号:90223831 上传时间:2019-06-09 格式:DOC 页数:22 大小:406.50KB
返回 下载 相关 举报
数据结构与算法离线作业_第1页
第1页 / 共22页
数据结构与算法离线作业_第2页
第2页 / 共22页
数据结构与算法离线作业_第3页
第3页 / 共22页
数据结构与算法离线作业_第4页
第4页 / 共22页
数据结构与算法离线作业_第5页
第5页 / 共22页
点击查看更多>>
资源描述

《数据结构与算法离线作业》由会员分享,可在线阅读,更多相关《数据结构与算法离线作业(22页珍藏版)》请在金锄头文库上搜索。

1、浙江大学远程教育学院数据结构与算法课程离线作业姓名:陈鑫学 号:714100012010年级:2014春学习中心:西溪一、填空题:(【序号,章,节】。)【1,1,2】线性结构中元素之间存在一对一关系,树形结构中元素之间存在1对多关系,图形结构中元素之间存在多对多关系。【2,1,2】为了最快地存取数据元素,物理结构宜采用顺序存储结构。【3,1,2】存储结构可根据数据元素在机器中的位置是否一定连续分为顺序存储结构_,_链式存储结构_。【4,1,3】度量算法效率可通过_来进行。【5,1,3】设n 为正整数,下面程序段中前置以记号的语句的频度是n(n+1)/2。 for (i=0; in; i+) f

2、or (j=0; jn; j+) if (i+j=n-1) aij=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; jnext=NULL _。【10,3,2】在一个单链表中p所指结点(p所指不是最后结点)之后插入一个由指针s所指结点,应执行s-next=_p-next_;和p-next=_s_的操作。【11,3,2】在一个单链表中删除p所指结点时,应执行以下操作: q= p-nex

3、t; 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结点的直接前驱结点的语句序列是 10 12 8 11 4 14 _。b. 删除结点P的语句序列是_ 10 12 7 3 14_。c. 删除尾元结点的语句序列是_9 11 3 14_。

4、(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;(

5、12) P = L;(13) L = L-next;(14) free (Q);【14,3,3】对一个栈,给定输入的顺序是A、B、C,则全部不可能的输出序列有不可能得到的输出序列有CAB。【15,3,3】.在栈顶指针为HS的链栈中,判定栈空的条件是head-next=NULL。【16,3,3】下列程序把十进制数转换为十六进制数,请填写合适的语句成分。void conversion10_16() InitStack(&s); scanf(“%d”,&N); while(N)_Push(s, N%16) _; N = N/16; while(!StackEmpty(s)_Pop(s, e) _;

6、if(e=9)printf(“%d”,e); else printf(“%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】已

7、知一棵树边的集合是,。那么根结点是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个叶子结点,从上到下、从左到右对它的结点进行编号,根结点为1号。则该完全二叉树总共结点有_111_个;有_7_层;第91号结点的双亲结点是_45_号;第63号结点的左孩子结点是_34_号。【2

8、4,4,3】下列表示的图中,共有_5_个是树;有_3_个是二叉树;有_2_个是完全二叉树。【25,4,4】n个结点的二叉排序树的最大深度是n,最小深度为log2n+1。【26,4,3】如果某二叉树的后序遍历序列是ABCDEFGHI,中序遍历序列是ACBIDFEHG,则其先序遍历序列的第一个字母是I,最后一个字母是G。【27,4,3】下列二叉树的中序遍历序列是_DBNGOAEC_;后序遍历序列是_DNIGBECA_。【28,5,4】设HASH表的大小为n(n=10), HASH函数为h(x)=x % 7,如果二次探测再散列方法Hi=(H(key)+di) mod 10 (di = 12,22,3

9、2,)解决冲突,在HASH表中依次插入关键字1,14,55,20,84,27以后,关键字1、20和27所在地址的下标分别是1、_7_和5。插入上述6个元素的平均比较次数是2。【29,6,3】设无权图G的邻接矩阵为A,若(vi,vj)属于图G的边集合,则对应元素Aij等于1,22、设无向图G的邻接矩阵为A,若Aij等于0,则Aji等于0。【30,6,3】若一个图用邻接矩阵表示,则删除从第i个顶点出发的所有边的方法是矩阵第i行全部置为零。【31,6,2】设一个图G=V,A,V=a,b,c,d,e,f,A=,。那么顶点e的入度是2;出度是1;通过顶点f的简单回路有2条;就连通性而言,该图是强连通图;

10、它的强连通分量有1个;其生成树可能的最大深度是5。【32,7,1】排序过程一般需经过两个基本操作,它们是比较和移动。【33,7,2】在对一组关键字是(54,38,96,45,15,72,60,23,83)的记录进行直接插入排序时,当把第七个记录(关键字是60)插入到有序表时,为寻找插入位置需比较3次。【34,7,4】插入排序、希尔排序、选择排序、快速排序、堆排序、归并排序、和基数排序方法中,不稳定的排序方法有希尔排序、快速排序、堆排序。二、综合题(选自教材数据结构各章习题,采用word文件格式上传)【1,1,3】试分析下面一段代码的时间复杂度:if ( A B ) for ( i=0; ii;

11、 j- ) A += B;else for ( i=0; ii; j- ) A += B;答:if AB为真,则for语句的外循环N次,内循环为N(N-1)次,因此时间复杂度为O(N* N(N-1)),也就是N的三次方。 if AB为假,则for语句的外循环2N次,内循环为N次,因此时间复杂度为O(2N*N),也就是N的平方。【2,1,3】测试例1.3中秦九韶算法与直接法的效率差别。令,计算的值。利用clock()函数得到两种算法在同一机器上的运行时间。答:f(1.1)=137797.40625【3,1,3】试分析最大子列和算法1.3的空间复杂度。【4,1,3】试给出判断是否为质数的的算法。答:int sushu(int N) int i;int flag=1; if (N=1) return false;/1既不是合数也不是质数 if (N=2) return true; for (i=2;i=sqrt(N);i+) if (N%i=0) flag=0 break; return flag; 【5,2,2】请编写程序,输入整数n和a,输出S=a+aa+aaa+aaa(n个a)的结果。答: #includestdio.h int main()

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 商业/管理/HR > 管理学资料

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号