浙大远程数据结构与算法离线答案完整版.docx
- 文档编号:27041640
- 上传时间:2023-06-26
- 格式:DOCX
- 页数:52
- 大小:586.49KB
浙大远程数据结构与算法离线答案完整版.docx
《浙大远程数据结构与算法离线答案完整版.docx》由会员分享,可在线阅读,更多相关《浙大远程数据结构与算法离线答案完整版.docx(52页珍藏版)》请在冰豆网上搜索。
浙大远程数据结构与算法离线答案完整版
浙江大学远程教育学院
《数据结构与算法》课程离线作业
一、填空题:
(【序号,章,节】。
。
。
。
。
。
)
【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 for(j=0;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________________。 } 【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==null____;不带头结点的单循环链表的判空条件是__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; (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】已知一棵树边的集合是{, 那么根结点是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号结点的左孩子结点是_________号。 【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,如果二次探测再散列方法Hi=(H(key)+di)mod10(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的边集合,则对应元素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={,,, 那么顶点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】插入排序、希尔排序、选择排序、快速排序、堆排序、归并排序、和基数排序方法中,不稳定的排序方法有选择排序、快速排序、堆排序、希尔排序 二、综合题(选自教材《数据结构》各章习题,采用word文件格式上传) 【1,1,3】试分析下面一段代码的时间复杂度: if(A>B){ for(i=0;i for(j=N*N;j>i;j--) A+=B; } else{ for(i=0;i for(j=N*2;j>i;j--) A+=B; } if中的时间复杂度为: O(n*n²)即O(n³) else中的时间复杂度为: O(n*n)即O(n²) 【2,1,3】测试例1.3中秦九韶算法与直接法的效率差别。 令 ,计算 的值。 利用clock()函数得到两种算法在同一机器上的运行时间。 答: 从运行结果可以看出秦九昭算法效率上有很大优势; #include #include #include clock_tstart,stop; doubleduration; #defineMAXN10 #defineMAXK1e7 doublef1(intn,doublea[],doublex); doublef2(intn,doublea[],doublex); //秦九昭算法 doublef1(intn,doublea[],doublex){ inti=0; doublep=a[0]; for(i=n;i>0;i--) p=a[i-1]+x*p; returnp; } //直接算法 doublef2(intn,doublea[],doublex){ inti=0; doublep=a[0]; for(i=n;i>0;i--) p+=a[i]*pow(x,i); returnp; } intmain(){ inti; doublea[MAXN]; for(i=0;i a[i]=(double)i; start=clock(); for(i=0;i f2(MAXN-1,a,1.1); stop=clock(); duration=((double)(stop-start))/CLK_TCK/MAXK; printf("直接算法: "); printf("ticks=%f\n",(double)(stop-start)); printf("duration=%6.2e\n",duration); for(i=0;i a[i]=(double)i; start=clock(); for(i=0;i f1(MAXN-1,a,1.1); stop=clock(); printf("秦九昭算法: "); printf("ticks=%f\n",(double)(stop-start)); printf("duration=%6.2e\n",duration); return0; } 【3,1,3】试分析最大子列和算法1.3的空间复杂度。 答: 在1.4中存在4种解决最大子列的算法,具体空间复杂度如下: 1、穷举法: 算法并没有开辟另外的存储空间进行存储,利用的是累加所以空间复杂度为O (2); 2、部分穷举: 同上 3、分而治之: 利用递归解决问题,故空间复杂度为O(N); 4、在线处理: 为O (2); 【4,1,3】试给出判断 是否为质数的 的算法。 答案: #include #include intis_prime(intn) { inti=0; if(n! =2&&n%2==0) { return0; } for(i=3;i<=sqrt((double)n);i+=2) { if(n%i==0) { return0; } } return1; } voidmain() { intnum=0,result=0; printf("Inputthenum: "); scanf("%d",&num); result=is_prime(num); if(result) printf("%disaprime\n",num); else printf("%disnotaprime\n",num); } Inputthenum: 5 5isaprime. 【5,2,2】请编写程序,输入整数n和a,输出S=a+aa+aaa+…+aa…a(n个a)的结果。 答案: #include"stdio.h" intmain() { 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逐步增大时程序的运行时间。 答案: #include #include voidpailie(int*data,intn,intcurr) { inti=0; if(curr==n-1) { for(i=0;i printf("%d",data[i]); printf("\n"); } else { for(i=curr;i { intt; t=data[curr],data[curr]=data[i],data[i]=t; pailie(data,n,curr+1); t=data[curr],data[curr]=data[i],data[i]=t; } } } intmain() { clock_tend; clock_tstart=clock(); intn=0; inti=0; intas[10]={0,0,0,0,0,0,0,0,0,0};//n小于等于10 scanf("%d",&n); for(i=0;i { as[i]=i+1; } pailie(as,n,0); end=clock(); printf("Thetimewas: %d\n",(end-start)/CLK_TCK); return0; } N为7 N为9 分析来看时间上虽然有比较大的增长,但主要用于打印;但在时间复杂度上是随着n的变大呈直线上升趋势; 【7,3,2】给定一个顺序存储的线性表L=( , ),请设计一个算法删除所有值大于min而且小于max的元素。 SeqListDelete(SeqList&L,intmin,intmax) { inti;=0,j=0 for(i=0;i { if(L.elem[i]>min&&L.elem[i] { for(j=i;j { L.elem[j]=L.elem[j+1]; --L.length; } } } returnL; } 【8,3,2】给定一个顺序存储的线性表L=( , ),请设计一个算法查找该线性表中最长递增子序列。 例如,(1,9,2,5,7,3,4,6,8,0)中最长的递增子序列为(3,4,6,8)。 voidmain() { intn,i,j,k; intA[1024]={}; intdp[1024]={}; scanf("%d",&n); for(i=1;i<=n;i++) scanf("%d",A[i]); dp[1]=1; //有n个阶段 for(i=2;i<=n;i++) { dp[i]=1;//每个阶段只有1个状态 //每个状态有i种决策,以得出以元素i结尾的最长递归子序列的长度 for(j=i-1;j>=0;j--) { if(A[i]>A[j]) { dp[i]=max(dp[i],dp[j]+1); } } } intmaximum=dp[1]; for(i=2;i<=n;i++) { maximum=max(maximum,dp[i]); } printf("%dmaximumis: \n",maximum); } 【9,3,3】如果有1、2、3、4、5按顺序入栈,不同的堆栈操作(pop,push)顺序可得到不同的堆栈输出序列。 请问共有多少种不同的输出序列? 为什么? 答案: 按照正常情况,1,2,3,4,5的全排列组合共有5! =120,即120种,但由于 像: 12435、12534之类的无法按顺序出入栈,故按照顺序入栈的情况共有56种: 以1开始排列组合为14种 以2开始排列组合为14种 以3开始的排列组合为9种 以4开始的排列组合为4种 以5开始的排列组合为1种 【10,3,2】请编写程序将中缀表达式转换为后缀表达式。 答案: 使用栈的循序存储结构实现、栈的顺序存储结构,用一维数组实现 #include #include #defineOK1 #defineERROR-1 #defineTRUE1 #defineFALSE0 #defineMAXSIZE10 typedefintStatus; typedefcharElemType; typedefstruct{ ElemTypedata[MAXSIZE]; inttop;//栈顶指针 }Stack; //1.初始化 StatusInitStack(Stack*S){ inti; for(i=0;i S->data[i]=NULL; S->top=-1; returnOK; } //2.创建一个长度为n的堆栈 StatusCreateStack(Stack*S,intn){ inti=0; if(n>MAXSIZE||n<1){ printf("输入长度有误! \n"); returnERROR; } for(i=0;i S->data[i]=rand()%100+1; } S->top=n-1; returnOK; } Statuspush(Stack*S,ElemTypee){ if(MAXSIZE-1==S->top){ printf("栈已满\n"); returnERROR; } //栈顶指向的元素有值 ++(S->top); S->data[S->top]=e; returnOK; } //4.出栈 Statuspop(Stack*S,ElemType*e){ //将栈顶元素出栈,传给e if(-1==S->top){ printf("栈为空! \n"); returnERROR; } *e=S->data[S->top]; --(S->top); returnOK; } //5.中缀表达式转后缀表达式 voidMidToFinal(char*mid,char*final){ //中缀表达式为middle,要转换成后缀表达式传给last //新建一个栈,来存储符号 chare; StackS; if(OK! =InitStack(&S)){ printf("初始化栈失败! \n"); } //当带转换的字符串*mid未终止时,循环处理 while(*mid){ //如果是数字,则直接输出 if(*mid>='0'&&*mid<='9'){ *(final++)=*(mid++); continue; }elseif(*mid=='+'||*mid=='-'||*mid=='*'||*mid=='/'||*mid=='('||*mid==')'){ //输入的是合法运算符号,比较之前是否有更高优先级的符号 if(S.top==-1||'('==*mid){ //当符号栈为空或遇到左括号时,符号入栈 push(&S,*(mid++)); continue; } if(')'==*mid){ //遇到右括号时,栈顶元素依次出栈;直到遇到第一个左括号时结束 pop(&S,&e); *(final++)=e; while(pop(&S,&e)&&e! ='('){ *(final++)=e; } //printf("%c\n",e); mid++; continue; }
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 浙大 远程 数据结构 算法 离线 答案 完整版