浙大远程数据结构与算法离线答案完整版.docx
《浙大远程数据结构与算法离线答案完整版.docx》由会员分享,可在线阅读,更多相关《浙大远程数据结构与算法离线答案完整版.docx(41页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、浙江高校远程教化学院数据构造及算法课程离线作业一, 填空题:【序号,章,节】。【1,1,2】线性构造中元素之间存在一对一关系,树形构造中元素之间存在一对多关系,图形构造中元素之间存在多对多关系。【2,1,2】为了最快地存取数据元素,物理构造宜接受 序存储 构造。3,1,2】数据构造的三要素是 逻辑构造, 物理构造 , 操作 。【3,1,2】存储构造可依据数据元素在机器中的位置是否确定连续分为依次存储构造,链式存储构造。【4,1,3】度量算法效率可通过 时间困难度和空间困难度_来进展。【5,1,3】设n 为正整数,下面程序段中前置以记号的语句的频度是 n(n+1)/2 。 for (i=0; i
2、n; 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=null _; 不带头结点的单循环链表的判空条件是_ Head=null_。【13,3,2】L是带表头结点的非空单链表, 且P结点既然不首元结点,也不是尾元结点,试从以下供应的答案中选择适宜的语句序列。a. 删除P结点的干脆前驱结点的语句序列是_10 12 8 11 4 14_。b. 删除结点P的语句序列是_10 12 7 3 14_。c. 删除尾元结点的语句序列是_9 1
4、1 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 = P;(11) Q =
5、P-next;(12) P = L;(13) L = L-next;(14) free (Q);【14,3,3】对一个栈,给定输入的依次是A, B, C,那么全部不行能的输出序列有 C A B 。【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(
6、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。当从队列中删除一个元素,再参加两个元素后,rear和front的值分别是
7、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_个;有_7_层;第91号结点的双亲结
8、点是_45_号;第63号结点的左孩子结点是_号。【24,4,3】以下表示的图中,共有_5_个是树;有_3_个是二叉树;有_2_个是完全二叉树。【25,4,4】n个结点的二叉排序树的最大深度是 n ,最小深度为 log2+1 _ 【26,4,3】假如某二叉树的后序遍历序列是ABCDEFGHI,中序遍历序列是ACBIDFEHG,那么其先序遍历序列的第一个字母是 I ,最终一个字母是 G 。【27,4,3】以下二叉树的中序遍历序列是_ DBNGOAEC _ _;后序遍历序列是_ DNOGBECA _。 【28,5,4】设HASH表的大小为 n (n=10), HASH函数为 h(x)=x % 7,
9、假如二次探测再散列方法Hi=(H(key)+di) mod 10 (di = 12,22,32,)解决冲突,在HASH表中依次插入关键字1,14,55,20,84,27以后,关键字1, 20和27所在地址的下标分别是 , _ 和 。插入上述6个元素的平均比拟次数是 。答案:1, 7, 5, 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】设一
10、个图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 次 分别及54, 72, 96比拟【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;if中的时间困难度为:O(n*n)即O(n)else中的时间困难度为:O(n*n)即O(n)【2,1,3】秦九韶算法及干脆法的效率差异。令,计算的值。利用clock()函数得到两种算法在同一机器上的运行时间。答:从运行结果可以看出秦九昭算法效率上有很大优势;#include #incl
12、ude #include clock_t start,stop;double duration;#define MAXN 10#define MAXK 1e7double f1(int n ,double a,double x);double f2(int n ,double a,double x);/秦九昭算法double f1(int n ,double a,double x)int i =0 ;double p = a0;for(i=n;i0;i-)p = ai-1 + x * p;return p;/干脆算法double f2(int n ,double a,double x)int
13、i =0 ;double p = a0;for(i=n;i0;i-)p += ai*pow(x,i);return p;int main()int i ;double aMAXN ;for(i=0;iMAXN;i+)ai=(double)i;start = clock();for(i=0;iMAXK;i+)f2(MAXN-1,a,1.1);stop = clock();duration = (double)(stop-start)/CLK_TCK/MAXK ;printf(干脆算法:);printf(ticks = %fn,(double)(stop-start);printf(duratio
14、n = %6.2en,duration);for(i=0;iMAXN;i+)ai=(double)i;start = clock();for(i=0;iMAXK;i+)f1(MAXN-1,a,1.1);stop = clock();printf(秦九昭算法:);printf(ticks = %fn,(double)(stop-start);printf(duration = %6.2en,duration);return 0;【3,1,3】 试分析最大子列和算法1.3的空间困难度。答:存在4种解决最大子列的算法,具体空间困难度如下:1、 穷举法:算法并没有开拓另外的存储空间进展存储,利用的是累
15、加所以空间困难度为O(2);2、 局部穷举:同上3、 分而治之:利用递归解决问题,故空间困难度为O(N);4、 在线处理:为O(2);【4,1,3】试给出推断是否为质数的的算法。答案:#include #include int is_prime(int n)int i = 0; if(n!= 2 & n % 2 = 0) return 0; for(i=3;i=sqrt(double)n);i+=2) if(n % i = 0) return 0; return 1;void main()int num = 0 ,result =0 ;printf(Input the num:); scanf
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 浙大 远程 数据结构 算法 离线 答案 完整版
限制150内