ImageVerifierCode 换一换
格式:DOCX , 页数:29 ,大小:204.67KB ,
资源ID:29278131      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/29278131.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(浙大远程数据结构与算法离线作业答案剖析.docx)为本站会员(b****5)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

浙大远程数据结构与算法离线作业答案剖析.docx

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

2、; i+) for (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所指结点时

3、,应执行以下操作: 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结点的直接前驱结点的语句序列是_10 12 8 11 4 14 _。b. 删除结点P的语句序列是_10 12 7 3 14_。c. 删除尾元结

4、点的语句序列是_9 11 3 14_。(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 =

5、P;(11) Q = P-next;(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(!Sta

6、ckEmpty(s) _Pop(s, e)_ ; 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。当从队列中删除一个元素,再加入两个元素后

7、,rear和front的值分别是 2 和 4 。【20,4,2】已知一棵树边的集合是,。那么根结点是 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

8、_个;有_7_层;第91号结点的双亲结点是_45_号;第63号结点的左孩子结点是_号。【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 _。 【28,5,4】设HASH表的大小为 n (n=10), HA

9、SH函数为 h(x)=x % 7, 如果二次探测再散列方法Hi=(H(key)+di) mod 10 (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的边集合,则对应元素Aij等于 1 ,22、设无向图G的邻接矩阵为A,若Aij等于0,则Aji等于 0 。【30,6,3】若一个图用邻接矩阵表示,则删除从第i个顶点出发的所有边的方法是 矩阵第i行全部置为零 。【31

10、,6,2】设一个图G=V,A,V=a,b,c,d,e,f,A=,。那么顶点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】插入排序、希尔排序、选择排序、快速排序、堆排序、归并排序、和基数排序方法中,不稳定的排序方法

11、有 希尔排序、快速排序、堆排序 。二、综合题(选自教材数据结构各章习题,采用word文件格式上传)【1,1,3】试分析下面一段代码的时间复杂度:if ( A B ) for ( i=0; ii; j- ) A += B;else for ( i=0; ii; j- ) A += B;【2,1,3】测试例1.3中秦九韶算法与直接法的效率差别。令,计算的值。利用clock()函数得到两种算法在同一机器上的运行时间。直接法:0.1s秦九韶算法 :0.04s【3,1,3】 试分析最大子列和算法1.3的空间复杂度。【4,1,3】试给出判断是否为质数的的算法。#includeint a1000001=0;

12、int main() int i,j; i=2; a1=1; while(i=500000) for(j=2;i*j=1000001;j+) ai*j=1; i+; while(ai=1) i+; scanf(%d,&i); while(i!=0) if(ai=0) printf(素数n); else printf(不是素数n); scanf(%d,&i); return 0;【5,2,2】请编写程序,输入整数n和a,输出S=a+aa+aaa+aaa(n个a)的结果。#includestdio.h int main() int a,b,n,i,s=0; scanf(%d %d,&a,&n);

13、b=a; for(i=1;i=n;i+) s+=a; a=a*10+b; printf(%dn,s); 【6,2,3】请编写递归函数,输出123.n的全排列(n小于10),并观察n逐步增大时程序的运行时间。#include #define N 8int n = 0; void swap(int *a, int *b) int m; m= *a; *a = *b; *b = m; void perm(int list, int k, int m) int i; if(k m) for(i = 0; i = m; i+) printf(%d, listi); printf(n); n+; else

14、 for(i = k; i = max) return ERROR; for(i=0;imin & L.elemimax) for(j=i;jL.length;j+) L.elemj=L.elemj+1; -L.length; return OK;【8,3,2】给定一个顺序存储的线性表L = (, , , ),请设计一个算法查找该线性表中最长递增子序列。例如,(1,9,2,5,7,3,4,6,8,0)中最长的递增子序列为(3,4,6,8)。#include#includeusingnamespacestd;#defineMAXN1003intAMAXN;intdpMAXN;/动态规划思想O(n

15、2)intmain()intn,i,j,k;cinn;for(i=1;iAi;dp1=1;for(i=2;i=0;j-)if(AiAj)dpi=max(dpi,dpj+1);intmaximum=dp1;for(i=2;i=n;i+)maximum=max(maximum,dpi);coutmaximum;【9,3,3】 如果有1、2、3、4、5按顺序入栈,不同的堆栈操作(pop, push)顺序可得到不同的堆栈输出序列。请问共有多少种不同的输出序列?为什么?如果1、2、3、4、5本来已经在栈中的话,那第一个push 是将一个空的入栈,pop出一个空的,在push一个空的,在pop一个空的。这

16、样的话,最后输出的是由尾到头:5、4、3、2、1【10,3,2】请编写程序将中缀表达式转换为后缀表达式。#include #include #include using namespace std;int prior(char op)if(op=+|op=-) return 1;if(op=*|op=/) return 2;return 0;string middletolast(string middle)stack op;string ans; for(int i=0;i=0&cprior(op.top() op.push(c); else while(!op.empty()&prior(

17、c)mdata; res=middletolast(mdata);for(int i=0;ires.size();i+) if(i=0) coutresi; else cout resi;coutendl;return 0;【11,4,3】设二叉树的存储结构如下:12345678910Lchild00237580101dataJHFDBACEGIRchild0009400000其中根结点的指针值为6,Lchild,Rchild分别为结点的左、右孩子指针域,data为数据域。(1)画出二叉树的逻辑结构。(2)写出该树的前序、中序和后序遍历的序列。前序序列: ABCEDFHGI 中序序列: ECB

18、HFDJIGA 后序序列: ECHFJIGDBA【12,4,4】可以生成如下二叉排序树的关键字的初始排列有几种?请写出其中的任意4个。解:30种。任写4个序列如下:(5,4,7,6,2,3,1);(5,7,4,6,2,3,1);(5,4,7,2,3,1,6);(5,7,6,4,2,3,1);【13,4,5】给定关键字序列(11、7、16、4、22、13、5),请回答:(1)画出依次插入到一棵空的二叉排序树后的最终二叉树(6分);(2)画出依次把给定序列关键字插入一棵空的平衡二叉树后的结果(4分);【14,4,6】 假设一个文本使用的字符集为a,b,c,d,e,f,g, 字符的哈夫曼编码依次为0

19、110,10,110,111,00,0111,010。(1)请根据哈夫曼编码画出此哈夫曼树,并在叶子结点中标注相应的字符;(2)若这些字符在文本中出现的频率分别为:3,35,13,15,20,5,9,求该哈夫曼树的带权路径长度。答:WPL=4*(3+5)+3*(9+13+15)+2*(20+35)=253【15,5,3】用公式5.6计算一下你的身份证号码的散列值是多少。答:5【16,5,4】设有一组关键字29,01,13,15,56,20,87,27,69,9,10,74,散列函数为:H(key) = key % 17,采用平方探测方法解决冲突。试在0到18的散列地址空间中对该关键字序列构造散

20、列表。【17,5,4】将关键字序列(7,8,30,11,18,9,14)散列存储到散列列表中,散列表的存储空间是一个下标从0开始的一个一维数组。处理冲突采用线性探测法,散列函数为:H(key)=(key3)mod TableSize,要求装入因子为0.7。答:(1)由装载因子0.7,数据总数7个存储空间长度为10P=10所以,构造的散列表为:01234567893071411818.9.H(7)=(73)MOD10=1(2)查找成功的ASL=(1+1+1+1+2+1+1)/7=8/7查找不成功的ASL=(7+6+5+4+3+2+1+2+1+1)/10=3.2【18,6,3】已知一个无向图的顶点

21、集为V0,V1,V7,其邻接矩阵如下所示:V0 0 1 0 1 1 0 0 0V1 1 0 1 0 1 0 0 0V2 0 1 0 0 0 1 0 0V3 1 0 0 0 0 0 1 0V4 1 1 0 0 0 0 1 0V5 0 0 1 0 0 0 0 0V6 0 0 0 1 1 0 0 1V7 0 0 0 0 0 0 0 1(1) 画出该图的图形; (2) 给出从V0出发的深度优先遍历序和广度优先遍历序。答:深度优先序列V0,V1,V2,V5,V4,V6,V3,V7广度优先序列V0V1V3V4V2V6V5V7【19,6,3】已知有向图如右图所示,请给出该图的(1)每个顶点的入度和出度; (2)邻接矩阵;(3)邻接表;(4)逆邻接表;(5)各个强连通分量。答 :1各顶点的入度和出度如下:3/0 2/2 1/2 1/2 2/1 2/3邻接矩阵如下:123456100000021001

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1