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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

算法设计与分析复习题目及答案.docx

1、算法设计与分析复习题目及答案分治法1、二分搜索算法是利用( 分治策略)实现的算法。9. 实现循环赛日程表利用的算法是(分治策略 )27、Strassen 矩阵乘法是利用(分治策略 )实现的算法。实现大整数的乘法是利用的算法( 分治策略 )。不可以使用分治法求解的是( 0/1 背包问题 )。动态规划下列不是动态规划算法基本步骤的是( 构造最优解 )下列算法中通常以自底向上的方式求解最优解的是(动态规划法 备忘录方法是那种算法的变形。 ( 动态规划法 ) 最长公共子序列算法利用的算法是( 动态规划法 )。矩阵连乘问题的算法可由(动态规划算法 B)设计实现。贪心算法 能解决的问题:单源最短路径问题,

2、最小花费生成树问题,背包问题,活动安排 问题, 不能解决的问题:N皇后问题,0/1背包问题 是贪心算法的基本要素的是(贪心选择性质和最优子结构性质) 。回溯法 回溯法解旅行售货员问题时的解空间树是( 排列树 )。剪枝函数是回溯法中为避免无效搜索采取的策略 回溯法的效率不依赖于下列哪些因素( 确定解空间的时间)分支限界法最大效益优先是( 分支界限法 )的一搜索方式。分支限界法解旅行售货员问题时,活结点表的组织形式是( 最小堆 ) 优先队列式分支限界法选取扩展结点的原则是( 结点的优先级 ) 在对问题的解空间树进行搜索的方法中 , 一个活结点最多有一次机会成为活结点 的是 ( 分支限界法 ).从活

3、结点表中选择下一个扩展结点的不同方式将导致不同的分支限界法 , 以下除( 栈式分支限界法 ) 之外都是最常见的方式 .(1)队列式(FIFO)分支限界法:按照队列先进先出(FIFO)原则选取下一个节点为扩展节点。2)优先队列式分支限界法:按照优先队列中规定的优先级选取优先级最高的节点成为当前扩展节点。最优子结构性质)是贪心算法与动态规划算法的共同点。)。贪心算法与动态规划算法的主要区别是( 贪心选择性质21、下面关于NP问题说法正确的是(B)A NP问题都是不可能解决的问题B P类问题包含在NP类问题中C NP完全问题是P类问题的子集D NP类问题包含在P类问题中 40、背包问题的贪心算法所需

4、的计算时间为(42. 0-1背包问题的回溯算法所需的计算时间为(O(n)D O(n)A、O(n2n) B O (nlogn ) C、O (2n)47.背包问题的贪心算法所需的计算时间为(A、O (n2n) B O (nlogn ) C、O(2n) 53 采用贪心算法的最优装载问题的主要计算量在于将集装箱依其重量从小到大排序,故算法的时间复杂度为 (B )A、O(n2n) B O (nlogn ) C、O (2n) D、O (n) 56、算法是由若干条指令组成的有穷序列,而且满足以下性质(输入:有0个或多个输入 输出:至少有一个输出确定性:指令清晰,无歧义A (1)(2)(3) B(1)(2)(

5、4) C(1)(3)(4) D (1) (2)(3)(4)57、函数32n+10nlogn的渐进表达式是(B ).61、设f(N),g(N)是定义在正数集上的正函数,如果存在正的常数C和自然数Nd,使得当NNo时有f(N) =b;将N中作业按a的非减序排序得到N将 2中作业按bi的非增序排序得到NNT中作业接N2中作业就构成了满 足Johnson法则的最优调度。3.若n=4 ,在机器 M1和M2上加工作业i所需的时间分别为 a和bi ,且 (a1,a2,a3,a4)=(4,5,12,10) , (b1,b2,b3,b4)=(8,2,15,9) 求 4 个作业的最优调度方 案,并计算最优值。步骤

6、为:N1=1 , 3 , N2=2 , 4;N =1 , 3, N2 =4 , 2;最优值为:384.使用回溯法解0/1背包问题:n=3, C=9, V=6,10,3 , W=3,4,4,其解空间有 长度为3的0-1向量组成,要求用一棵完全二叉树表示其解空间 (从根出发,左 1右0),并画出其解空间树,计算其最优值及最优解。解空间为(0,0,0),(0,1,0),(0,0,1),(1,0,0),(0,1,1),(1,0,1), (1,1,0),(1,1,1) 。解空间树为:该问题的最优值为:165.设 S= X, X2,,Xn的元素,在表示S的二叉搜索树中搜索一个元素在二叉搜索树的内结点中找到

7、 X=X,其概率为bi。(2)在二叉搜索树的叶结点中确定X( X , X+1),其概率为ai。在表示S的二叉搜索树T中,设存储元素X 的结点深度为C;叶结点(X , X+1)的结点深度为di ,则二叉搜索树T的平均路 长P为多少?假设二叉搜索树Tij= X , X+1 ,X 最优值为mij,Wij= ai-1 +b+ +b+aj ,贝U mij(1=i=j=n) 递归关系表达式为什么?n n二叉树T的平均路长P= bi*(1 Ci) + aj*dji 1 j 0mij=Wij+mi nmik+mk+1j (l=i=jj)6.描述0-1背包问题。已知一个背包的容量为C,有n件物品,物品i的重量为

8、W,价值为V ,求应如何选择装入背包中的物品,使得装入背包中物品的总价值最大。三、 简答题(30分)1.流水作业调度中,已知有n个作业,机器M1和M2上加工作业i所需的时间分 别为ai和bi,请写出流水作业调度问题的johnson法则中对a和bi的排序算法。(函数名可写为sort(s,n)2.最优二叉搜索树问题的动态规划算法(设函数名 binarysearchtree)1.void sort(flowj ope s,i nt n)int i,k,j,l;for(i=1;iv=n-1;i+)ag!=0) k+;if(kn) break;ag=0) if(sk.asj.a) k=j;swa p(

9、si.i ndex,sk.i ndex);swa p(si.tag,sk.tag); l=i;sj.b) k=j;swa p( si.i ndex,sk.i ndex); ag,sk.tag); 2.void bin arysearchtree(i nt a,i nt b,i nt n ,i nt *m,i nt *s,i nt *w)int i,j,k,t,l;for(i=1;i=n+1;i+) wii-1=ai-1;mii-1=0;for(l=0;l=n-1;l+)l nit-s in gle-source(G,s)2.S=3.Q=VGQdo u=min(Q)S=S U ufor each

10、 vertex 3 do 4 四、 算法理解题(本题10分)根据优先队列式分支限界法,求下图中从 v1点到v9点的单源最短路径,请画出求得最优解的解空间树。要求中间被舍弃的结点用X标记,获得中间解的结 点用单圆圈O框起,最优解用双圆圈框起。五、 算法理解题(本题5分)设有n=2k(运动员要进行循环赛,现设计一个满足以下要求的比赛日程表:1每个选手必须与其他n-1名选手比赛各一次;2每个选手一天至多只能赛一次;3循环赛要在最短时间内完成。(1)如果n=2循环赛最少需要进行几天;(2)当 n=23=8 时,请画出循环赛日程表。六、算法设计题(本题 15 分)分别用贪心算法、动态规划法、回溯法设计

11、0-1 背包问题。要求:说明所使 用的算法策略;写出算法实现的主要步骤;分析算法的时间。七、算法设计题(本题 10 分)通过键盘输入一个高精度的正整数 n(n的有效位数W 240),去掉其中任意s 个数字后,剩下的数字按原左右次序将组成一个新的正整数。 编程对给定的 n 和 s,寻找一种方案,使得剩下的数字组成的新数最小。【样例输入】178543S=4【样例输出】13二、 简答题(本题 25 分,每小题 5 分)2、1、分治法的基本思想是将一个规模为n的问题分解为k个规模较小的子问题, 这些子问题互相独立且与原问题相同;对这 k 个子问题分别求解。如果子 问题的规模仍然不够小,则再划分为 k

12、个子问题,如此递归的进行下去, 直到问题规模足够小,很容易求出其解为止;将求出的小规模的问题的解 合并为一个更大规模的问题的解,自底向上逐步求出原来问题的解。 “最优化原理 ”用数学化的语言来描述:假设为了解决某一优化问题,需 要依次作出n个决策D1, D2,,Dn,如若这个决策序列是最优的,对于 任何一个整数k,1 kn ,不论前面k个决策是怎样的,以后的最优决 策只取决于由前面决策所确定的当前状态, 即以后的决策Dk+1,Dk+2,,Dn也是最优的。3、 某个问题的最优解包含着其子问题的最优解。这种性质称为 最优子结构性 质。4、 回溯法的基本思想 是在一棵含有问题全部可能解的状态空间树上

13、进行深度 优先搜索,解为叶子结点。搜索过程中,每到达一个结点时,则判断该结 点为根的子树是否含有问题的解, 如果可以确定该子树中不含有问题的解, 则放弃对该子树的搜索,退回到上层父结点,继续下一步深度优先搜索过 程。在回溯法中,并不是先构造出整棵状态空间树,再进行搜索,而是在 搜索过程,逐步构造出状态空间树,即边搜索,边构造。5、 P(Polynomial 问题) :也即是多项式复杂程度的问题。NP就是Non-deterministic Polynomial的问题,也即是多项式复杂程度的非确定性问题。NP C(N P Comp lete)问题,这种问题只有把解域里面的所有可能都穷举了之 后才能

14、得出答案,这样的问题是 NP里面最难的问题,这种问题就是 NPC可 题。三、 算法填空(本题 20 分,每小题 5 分)1、n后问题回溯算法!Mj&!Li+j&!Ri-j+N(2) Mj=Li+j=Ri-j+N=1; try(i+1,M,L,R,A) Aij=0(5) Mj=Li+j=Ri-j+N=02、 数塔问题。(1)c=r trc+=tr+1c(3)trc+=tr+1c+13、 Hanoi 算法(1)move(a,c)(2)Hanoi(n-1, a, c , b)(3)Move(a,c)4、 ( 1)pv=NIL(2)pv=u(3)v adju(4)Relax(u,v,w)1 2 3 4

15、5 6 782 1 4 36 5 873 4 1 27 8 564 3 2 18 7 655 6 7 8-12然后,依贪心选择策略,将尽 若将这种物品全部装入背包四、算法理解题(本题10 分)五、 (1) 8天(2分);(2)当n=23=8时,循环赛日程表(3分)。六、 算法设计题(本题15分)(1)贪心算法 0 (nlog (n) 首先计算每种物品单位重量的价值 Vi/Wi ,可能多的单位重量价值最高的物品装入背包。后,背包内的物品总重量未超过 C,则选择单位重量价值次高的物品并尽 可能多地装入背包。依此策略一直地进行下去,直到背包装满为止。具体算法可描述如下:void Knap sack(

16、i nt n,float M,float v,float w,float x)Sort(n,v,w);int i;for (i=1;i=n;i+) xi=0;float c=M;for (i=1;ic) break;xi=1;c-=wi;if (i=n) xi=c/wi;(2)动态规划法 O(nc)m(i , j)是背包容量为j,可选择物品为i , i+1,n时0-1背包问题的最 优值。由 0-1 背包问题的最优子结构性质, 可以建立计算 m(i , j) 的递归式如下。void KnapSack(int v,int w,int c,int n,int m11) int jMax=min(wn

17、-1,c);for (j=0;j=jMax;j+) /*m(n,j)=0 0=jwn*/ mnj=0;for (j=wn;j=wn*/ mnj=vn;for (i=n-1;i1;i-) int jMax=min(wi-1,c);for (j=0;j=jMax;j+) /*m(i,j)=m(i+1,j) 0=jwi*/ mij=mi+1j;for (j=wi;j=wn*/ mij=max(mi+1j,mi+1j-wi+vi);m1c=m2c;if(c=w1) m1c=max(m1c,m2c-w1+v1);(3)回溯法 O(2 n)cw: 当前重量 cp: 当前价值 bestp :当前最优值voi

18、d backtrack( int i)包问题的贪心算法void Knapsack(int n,float M,float v,float w,float x)Sort( n,v,w);int i;for (i=1;i=n ;i+) xi=0;float c=M;for (i=1;i=n ;i+) xi=1;c - =wi;if (i=n) xi=c/wi;2.最大子段和:动态规划算法int MaxSum(i nt n, int a)tempi atevciass Type void Quicksort (Type a, int p, int r)if (pvr) int q=P artiti

19、on(a,p,r);Tempi ate vclass Type void p erm(T ype list, int k, int m ) 定已按升序排好序的n个元素a0:n-1,现要在这n个元素中找出一特定元据此容易设计出二分搜索算法:tempi atevciass Type int Bin arySearch(T ype a, const Type& x, int l, i nt r)while (lv=r )int m = (l+r)/2);if (x = am) return m;if (x am) r = m-1; else l = m+1;return -1;6合并排序描述如下:

20、tempi atevciass Type void Mergesort(T ype a , i nt left, int right) if ( leftvright )int i=( left+right)/2;Mergesort(a, left, i );Mergesort(a, i+1, right);1、问题分析2、数学模型建立3、算法设计与选择4、算法指标5、算法分析2.算法定义:算法是指在解决问题时,按照某种机械步骤一定可以得到问题结果的处理过3.算法的三要素13.分治法与动态规划法的相同点是:将待求解的问题分解成若干个子问题,先求解子问题,然后从这些子问题的 解得到原问题的解。两

21、者的不同点是:适合于用动态规划法求解的问题,经分解得到的子问题往 往不是互相独立的。而用分治法求解的问题,经分解得到的子问题往往是互相独立的。回溯法中常见的两类典型的解空间树是子集树和排列树。22.请叙述动态规划算法与贪心算法的异同。共同点:都需要最优子结构性质,都用来求有优化问题。不同点: 动态规划:每一步作一个选择一依赖于子问题的解。贪心方法:每一步作一个选择一不依赖于子问题的解 。动态规划方法的条件:子问题的重叠性质。可用贪心方法的条件:最优子结构性质;贪心选择性质。动态规划:自底向上求解;贪心方法: 自顶向下求解。可用贪心法时, 动态规划方法可能不适用;可用动态规划方法时,贪心法可能不

22、适用。23.请说明动态规划方法为什么需要最优子结构性质。答:最优子结构性质是指大问题的最优解包含子问题的最优解。动态规划方法是自底向上计算各个子问题的最优解,即先计算子问题的最优解,然后再利用子问题的最优解构造大问题的最优解,因此需要最优子结构.24.请说明: (1)优先队列可用什么数据结构实现?(2)优先队列插入算法基本思想?(3)优先队列插入算法时间复杂度?答:(1)堆。(2)在小根堆中,将元素x插入到堆的末尾,然后将元素x的关键字与其双亲的关键字比较,则将元素x与其双亲交换,然后再将元素x与其新双亲的关键字相比, 直到元素x的关键字大于双亲的关键字,或元素 x到根为止。(3)0( log

23、 n) 26.在算法复杂性分析中,OQ、这三个记号的意义是什么?在忽略常数因子的情况下,O Q、分别提供了算法运行时间的什么界?答: 如果存在两个正常数c和N0,对于所有的NN0,有|f(N| N0时有|f(N)| qg(N)|,记为如果存在正常数c1,c2 和 nO,对于所有的 nnO,有 c1|g(N)| |f(N)| 则记作c2|g(N)|f(N= ( g,( N)O Q、分别提供了算法运行时间的上界、下界、平均五、算法设计与分析题1.用动态规划策略求解最长公共子序列问题:给出计算最优值的递归方程。给定两个序列X=B,C,D,A , Y=A,B,C,B,请采用动态规划策略求出其最长公共子

24、序列,要求给出过程。0 P0 1.1 0 1 20 1 2 2 &2.对下列各组函数f最长公共子序列:BC (n)和 g (n),确定 f (n) = O(g (n)或 f (n) =Q (g (n) f(n)= Vn ; g (n)=log n 2 f(n )=100 ; g(n )=log100 f(n)=n 3 ; g(n)= 3n f(n )=3 n ; g(n )=2n答:(1)f( n) = O(g( n)因为g(n)的阶比f(n)的阶高。(2)f( n) = Q (g( n)因为g(n)的阶比f(n)的阶低。(3)f(n) = 0 (g(n)因为g(n)与f(n)同阶。(4)f(

25、 n) = O(g( n)因为g(n)的阶比f(n)的阶高。(5)f( n) = Q (g( n)因为g(n)的阶比f(n)的阶低。G,请写出在算法执行过程中,依次加入 T的边集TE中的边。说明该算法的贪心策 略和算法的基本思想,并简要分析算法的时间复杂度。答:TE=(3,4), (2,3),(1,5), ( 4,6)( 4,5)贪心策略是每次都在连接两个不同连通分量的边中选权值最小的边。基本思想:首先将图中所有顶点都放到生成树中,然后每次都在连接两个不同连通分量的边中选权值最小的边,将其放入生成树中,直到生成树中有n-1条边。时间复杂度为:O(eloge)4.请用分治策略设计递归的归并排序算

26、法,并分析其时间复杂性(要求:分别给出divide、conquer、combine这三个阶段所花的时间,并在此基础上列出递归方程,最后用套用公式法求出其解的渐进阶)。答 : Tempi ate class Typevoid MergeSort (Type a , i nt left, i nt right)Merge(a, b, left, right);Copy(a, b, left, right);Divide阶段的时间复杂性:O(1)Conquer阶段的时间复杂性:2T(n)Combine阶段的时间复杂性: (n)T(n) = (niogn)1 2 3 4 5 6 71234567821436587341278564321

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

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