您好,欢迎访问三七文档
1-6一、填空题(本题10分,每空1分)1、算法的复杂性是的度量,是评价算法优劣的重要依据。2、设n为正整数,利用大“O(·)”记号,将下列程序段的执行时间表示为n的函数,则下面程序段的时间复杂度为。i=1;k=0;while(in){k=k+10*i;i++;}3、计算机的资源最重要的是和资源。因而,算法的复杂性有和之分。4、f(n)=6×2n+n2,f(n)的渐进性态f(n)=O()5、递归是指函数或者通过一些语句调用自身。6、分治法的基本思想是将一个规模为n的问题分解为k个规模较小的子问题,这些子问题互相且与原问题相同。二、选择题(本题20分,每小题2分)1、分支限界法与回溯法都是在问题的解空间树T上搜索问题的解,二者(B)。A.求解目标不同,搜索方式相同B.求解目标不同,搜索方式也不同C.求解目标相同,搜索方式不同D.求解目标相同,搜索方式也相同2、回溯法在解空间树T上的搜索方式是(A)。A.深度优先B.广度优先C.最小耗费优先D.活结点优先3、在对问题的解空间树进行搜索的方法中,一个活结点最多有一次机会成为活结点的是(B)。A.回溯法B.分支限界法C.回溯法和分支限界法D.回溯法求解子集树问题4、以下关于判定问题难易处理的叙述中正确的是(C)。A.可以由多项式时间算法求解的问题是难处理的B.需要超过多项式时间算法求解的问题是易处理的C.可以由多项式时间算法求解的问题是易处理的D.需要超过多项式时间算法求解的问题是不能处理的5、设f(N),g(N)是定义在正数集上的正函数,如果存在正的常数C和自然数N0,使得当N≥N0时有f(N)≤Cg(N),则称函数f(N)当N充分大时有上界g(N),记作f(N)=O(g(N)),即f(N)的阶(A)g(N)的阶。A.不高于B.不低于C.等价于D.逼近6、对于含有n个元素的子集树问题,最坏情况下其解空间的叶结点数目为(B)。A.n!B.2nC.2n+1-1D.2n-17、程序可以不满足以下(D)特征A.输入B.输出C.确定性D.有限性8、以下(C)不能在线性时间完成排序A.计数排序B.基数排序C.堆排序D.桶排序9、以下(A)不一定得到问题的最优解A.贪心算法B.回溯算法C.分支限界法D.动态规划法10、以下(C)不包括在图灵机结构中2-6A.控制器B.读写磁头C.计算器D.磁带三、简答题(本题20分,每小题5分)1、设有n=2k个运动员要进行循环赛,现设计一个满足以下要求的比赛日程表:①每个选手必须与其他n-1名选手比赛各一次;②每个选手一天至多只能赛一次;③循环赛要在最短时间内完成。(1)如果n=2k,循环赛最少需要进行几天;(2)当n=22=4时,请画出循环赛日程表。2、简述最优子结构性质。3、简单描述回溯法基本思想。4、何谓P、NP问题四、算法填空(本题30分,每空2分)1、Dijkstra算法是解单源最短路径问题的贪心算法。请你阅读下面伪代码并在空白处填上适当的代码。//G是一个n个结点的有向图,它由成本邻接矩阵w[u,v]表示,D[v]表示结点v到源结点s的最短路径长度,p[v]记录结点v的父结点。Init-single-source(G,s)1.foreachvertexv∈V[G]2.do{d[v]=∞p[v]=NIL}3.d[s]=0Relax(u,v,w)1.ifd[v]d[u]+w[u,v]2.then{d[v]=d[u]+w[u,v]p[v]=u}dijkstra(G,w,s)1.init-single-source(G,s)2.S=Φ3.Q=V[G]4.whileQΦdou=min(Q)S=S∪{u}foreachvertexv∈adj[u]//所有u的邻接点vdorelax(G,v,w)2、某工厂预计明年有N个新建项目,每个项目的投资额w[k]及其投资后的收益v[k]已知。投资总额为C,问如何选择项目才能使总收益最大。Invest-Program()3-6{for(j=0;j=C;j++)5for(j=w[n];j=C;j++)m[n][j]=v[n];for(i=n-1;i1;i--){intjMax=min(w[i]-1,c);for(j=0;j=jMax;j++)m[i][j]=6;for(j=w[i];j=C;j++)m[i][j]=max(7);}m[1][c]=m[2][c];if(8)m[1][c]=max(m[1][c],m[2][c-w[1]]+v[1]);}3、N后问题(1)用二维数组A[N][N]存储皇后位置,若第i行第j列放有皇后,则A[i][j]为非0值,否则值为0。(2)分别用一维数组M[N]、L[2*N-1]、R[2*N-1]表示竖列、左斜线、右斜线是否放有棋子,有则值为1,否则值为0。for(j=0;jN;j++)if(9)/*安全检查{A[i][j]=i+1;/*放皇后*/10;if(i==N-1)输出结果;else11;;/*试探下一行*/12;/*去皇后*/13;;}4、通过键盘输入一个高精度的正整数n(n的有效位数≤240),去掉其中任意s个数字后,剩下的数字按原左右次序将组成一个新的正整数。编程对给定的n和s,寻找一种方案,使得剩下的数字组成的新数最小。delete(n,s){输入s,n;while(s0){i=1//从串首开始找while((ilength(n))&&n[i]n[i+1])//找比较大的数字i++;delete(n,i);//删除串n的第i个字符s--;}4-6while(length(n)1)&&(n[1]=‘0’)delete(n,1);//删去串首可能产生的无用零输出n;}五、请你阐述prim算法的基本思想。并给出下图的最小生成树(要求画出生成树,分析过程可以省略)(本题10分)六、算法分析题(本题10分)数字全排列问题:任意给出从1到N的N个连续的自然数的各种排列。如N=3时,共有以下6种排列方式:123,132,213,231,312,321。算法描述如下。画出N=3时递归调用时堆栈变化情况,写出相对应i,j的值。设数组b的初始值为1,2,3。perm(intb[],inti){intk,j;if(i==N)输出;elsefor(j=i;j=num;j++){swap(b[i],b[j]);perm(b,i+1);swap(b[j],b[i]);}}/*初始调用时i=1;*/答案:一、填空题(本题10分,每空1分)1、算法效率2、O(n)3、时间、空间时间复杂度、空间复杂度4、2n5、直接间接6、独立5-6二、选择题(本题20分,每小题2分)1-5:BABCA6-10:BDCAC三、简答题(本题20分,每小题5分)1、(1)2k-1天(2分);(2)当n=22=4时,循环赛日程表(3分)。12342143341243212、某个问题的最优解包含着其子问题的最优解。这种性质称为最优子结构性质。3、回溯法的基本思想是在一棵含有问题全部可能解的状态空间树上进行深度优先搜索,解为叶子结点。搜索过程中,每到达一个结点时,则判断该结点为根的子树是否含有问题的解,如果可以确定该子树中不含有问题的解,则放弃对该子树的搜索,退回到上层父结点,继续下一步深度优先搜索过程。在回溯法中,并不是先构造出整棵状态空间树,再进行搜索,而是在搜索过程,逐步构造出状态空间树,即边搜索,边构造。4、P(Polynomial问题):也即是多项式复杂程度的问题。NP就是Non-deterministicPolynomial的问题,也即是多项式复杂程度的非确定性问题。四、算法填空(本题30分,每空2分)1、(1)d[v]d[u]+w(u,v)(2)Init-single-source(G,s)(3)Φ(4)Relax(u,v,w)2、(5)m[n][j]=0;(6)m[i+1][j](7)m[i+1][j],m[i+1][j-w[i]]+v[i](8)c=w[1]3、(9)!M[j]&&!L[i+j]&&!R[i-j+N](10)M[j]=L[i+j]=R[i-j+N]=1;(11)try(i+1,M,L,R,A)(12)A[i][j]=0(13)M[j]=L[i+j]=R[i-j+N]=04、(14)i=1;(15)(ilength(n))&&(n[i]n[i+1])五、阐述prim算法的基本思想(本题10分)(5分)prim算法的基本思想是:设G=(V,E)是连通带权图,V={1,2,…,n}。首先置U={1},然后,只要U是V的真子集,就作如下的贪心选择:选取满足条件i∈U,j∈V-U,且c[i][j]最小的边,将顶点j添加到U中。这个过程一直进行到U=V时为止。在这个过程中选取到的所有边恰好构成G的一棵最小生成树。6-6(5分)最小生成树如下:六、算法设计题(本题10分)perm(intb[],inti){intk,j;if(i==N)输出b数组各元素值;elsefor(j=i;j=N;j++){swap(b[i],b[j]);perm(b,i+1);(1)(2)(3)(4)(5)(6)(7)(8)(9)swap(b[j],b[i]);}}/*初始调用时i=1;*/输出2,1,3(5)i=3,j=2(4)i=1,j=2(3)i=3,j=3(1)i=1,j=1弹出、清空输出1,3,2输出1,2,3(2)i=3,j=2(7)i=1,j=3输出2,3,1(6)i=3,j=3(9)i=3,j=3输出3,2,1(8)i=3,j=2输出3,1,2
本文标题:算法考试试题及答案
链接地址:https://www.777doc.com/doc-5383417 .html