1、1 计算机算法设计与分析复习题 一 、 填空 题 1、一个算法复杂性的高低体现在计算机运行该算法所需的时间和存储器资源上,因此算法的复杂性有 时间 复杂性和 空间 复杂性之分。 2、 出自于 “ 平衡子问题 ” 的思想,通常分治法在分割原问题,形成若干子问题时,这些子问题的规模都大致 相同 。 3、使用二分搜索算法在 n 个有序元素表中搜索一个特定元素,在最佳情况下,搜索的时间复杂性为 O( 1),在最坏情况下,搜索的时间复杂性为 O( logn )。 4、已知一个分治算法耗费的计算时间 T(n), T(n)满足如下递归方程: 222 21 nnOnT nOnT )()/( )()(解得此递归
2、方可得 T(n)= O( lognn )。 5、动态规划算法有一个变形方法 备忘录方法 。这种方法不同于动态规划算法 “ 自底向上 ” 的填充方向,而是 “ 自顶向下 ” 的递归方向,为每个解过的子问题建立了备忘录以备需要时查看,同样也可避免相同子问题的重复求解。 6 递归的二分查找算法在 divide 阶段所花的时间是 O(1) , conquer 阶段所花的时间是 T(n/2) ,算法的时间复杂度是 O( log n) 。 7 Prim 算法利用 贪心 策略求解 最小生成树 问题,其时间复杂度是 O(n2) 。 8 背包问题 可用 贪心法 , 回溯法 等策略求解。 9用动态规划算法计算 矩
3、阵连乘问题的 最优值所花的时间是 O(n3) , 子问题空间大小是 O(n2) 。 10图的 m 着色问题可用 回溯 法求解,其解空间树中叶子结点个数是 mn ,解空间树中每个内结点的孩子数是 m 。 11单源最短路径问题可用 贪心法 、 分支限界 等策略求解。 12、 一个算法的优劣可以用( 时间复杂度 )与( 空间复杂度 )与来衡量。 13、 回溯法在问题的解空间中,按( 深度优先方式 )从根结点出发搜索解空间树。 14、 直接或间接地调用自身的算法称为( 递归算法 )。 15、 记号在算法复杂性的表示法中表示( 渐进确界或紧致界 )。 16、在分治法中,使子问题规模大致相等的做法是出自一
4、种( 平衡 (banlancing)子问题 )的思想。 17、 动态规划算法适用于解( 具有某种最优性质 )问题。 18、 贪心 算法做出的选择只是( 在某种意义上的局部 )最优选择。 2 19、 最优子结构性质的含义是 ( 问题的最优解包含其子问题的最优解 ) 。 20、 回溯法按( 深度优先 )策略从根结点出发搜索解空间树 。 21、拉斯维加斯算法找到的解一定是 ( 正确解 ) 。 22、按照符号 O的定义 O(f)+O(g)等于 O(maxf(n),g(n)。 23、二分搜索技术是运用( 分治 )策略的典型例子。 24、动态规划算法中,通常不同子问题的个数随问题规模呈( 多项式 )级增长
5、。 25、( 最优子结构性质 )和( 子问题重叠性质 )是采用动态规划算法的两个基本要素。 26、( 最优子结构性质 )和( 贪心选择性质 )是贪心算法的基本要素。 27、( 选择能产生最优解的贪心准则 )是设计贪心算法的核心问题。 28、分支限界法常以( 广度优先 ) 或( 以最小耗费 (最大效益 )优先 )的方式搜索问题的解空间树。 29、贪心选择性质是指所求问题的整体最优解可以通过一系列( 局部最优 )的选择,即贪心选择达到。 30、按照活结点表的组织方式的不同,分支限界法包括( 队列式 (FIFO)分支限界法 )和( 优先队列式分支限界法 )两种形式。 31、如果对于同一实例,蒙特卡洛
6、算法不会给出两个不同的正确解答,则称该蒙特 卡洛算法是( 一致的 )。 32、 哈夫曼编码可 利用( 贪心法 )算法实现。 33概率算法有 数值概率算法,蒙特卡罗( Monte Carlo)算法,拉斯维加斯( Las Vegas)算法和舍伍德( Sherwood)算法 34以自顶向下的方式求解最优解的 有( 贪心算法 ) 35、下列算法中通常以自顶向下的方式求解最优解的是( 贪心法 )。 36、 在对问题的解空间树进行搜索的方法中 ,一个活结点有多次机会成为活结点的是 ( 回溯法 ) 37、旅行售货员问题不能用()解决 可以用回溯法解决,分支限界法, NP 完全性理论与近似算法 38、贪心 算
7、法不能解决( 0-1 背包问题 N皇后问题 )。可以解决背包问题 39、投点法是( 概率算法 )的一种。 40、若线性规划问题存在最优解,它一定不在 ( 可行域内部 ) 二 、简答题 1、( 8 分)写出下列复杂性函数的偏序关系(即按照渐进阶从低到高排序): 232 3 l o g ! l o g 1 0n n nn n n n n n 3 参考解答: 321 0 l o g l o g 2 3 !n n nn n n n n n 2、( 8分)现在有 8 位运动员要进行网球循环赛,要设计一个满足以下要求的比赛日程表: ( 1) 每个选手必须与其他选手各赛一次; ( 2) 每个选手一天只能赛一
8、次; ( 3) 循环赛一共进行 n 1天。 请利用分治法的思想,给这 8位运动员设计一个合理的比赛日程。 参考解答: 1 2 3 4 5 6 7 8 2 1 4 3 6 5 8 7 3 4 1 2 7 8 5 6 4 3 2 1 8 7 6 5 5 6 7 8 1 2 3 4 6 5 8 7 2 1 4 3 7 8 5 6 3 4 1 2 8 7 6 5 4 3 2 1 3、( 8 分)某体育馆有一羽毛球场出租,现在总共有 10 位客户申请租用此羽毛球场,每个客户所租用的时间单元如下表所示, s(i)表示开始租用时刻, f(i)表示结束 租用时刻, 10个客户的申请如下表所示: i 1 2 3
9、 4 5 6 7 8 9 10 s(i) 0 3 1 5 3 5 11 8 8 6 f(i) 6 5 4 9 8 7 13 12 11 10 同一时刻,该羽毛球场只能租借给一位客户,请设计一个租用安排方案,在这 10 位客户里面,使得体育馆能尽可能满足多位客户的需求,并算出针对上表的 10个客户申请,最多可以安排几位客户申请。 参考解答: 将这 10 位客户的申请按照结束时间 f(i)递增排序,如下表: i 1 2 3 4 5 6 7 8 9 10 s(i) 1 3 0 5 3 5 6 8 8 11 f(i) 4 5 6 7 8 9 10 11 12 13 选择申请 1( 1,4) 依次检查后
10、续客户申请,只要与已选择的申请相容不冲突,则选择该申请。直到所有申请检查完毕。申请 4( 5,7)、申请 8( 8,11)、申请 10( 11,13) 最后,可以满足:申请 1( 1,4)、申请 4( 5,7)、申请 8( 8,11)、申请 10( 11,13)共 4个客户申请。这已经是可以满足的最大客户人数 。 4 4、( 8分)对于矩阵连乘所需最少数乘次数问题,其递归关系式为: 1i k j0 , m in , 1 , i k jijm i j m i k m k j p p p i j 其中 mi, j为计算矩阵连乘 Ai Aj所需的最少数乘次数, pi-1为矩阵 Ai的行,ip 为矩阵
11、 Ai的列。现有四个矩阵,其中各矩阵维数分别为: A1 A2 A3 A4 5010 1040 4030 305 p 0 p 1 p 1 p 2 p 2 p 3 p 3 p 4 请根据以上的递归关系,计算出矩阵连乘积 A1A2A3A4所 需要的最少数乘次数。 参考解答: 0 1 4024034 1 1 2 4 0 80 00 50 10 5 10 50 0 1 4 m in 1 2 3 4 20 00 0 60 00 50 40 5 36 00 0 1 3 4 4 27 00 0 0 50 30 5 34 50 010500m m p p pm m m p p pm m p p p 5、( 8分
12、)有这样一类特殊 0-1背包问题:可选物品 重量越轻的物品价值越高。 n=6, c=20, P=( 4, 8, 15, 1, 6, 3), W=( 5, 3, 2, 10, 4, 8)。 其中 n 为物品个数, c 为背包载重量, P 表示物品的价值, W 表示物品的重量。请问对于此 0-1 背包问题,应如何选择放进去的物品,才能使到放进背包的物品总价值最大,能获得的最大总价值多少? 参考解答: 因为该 0 1 背包问题比较特殊,恰好重量越轻的物品价值越高,所以优先取重量轻的 物品放进背包。最终可以把重量分别为 2, 3, 4, 5 的三个物品放进背包,得到的价值和为 15 + 8 + 6 +
13、 4 = 33,为最大值。 6.请用英文写出三种以上能求解 0-1背包问题的设计算法策略。 参考解答: Dynamic Programming Backtrack Branch-and-Bound (每答对一条给一分) 7.请说明动态规划方法为什么需要最优子结构性质。 参考解答: 最优子结构性质是指大问题的最优解包含子问题的最优解。 动态规划方法是自底向上计算各个子问题 的最优解,即先计算子问题的最优解,然后再利用子问题的最优解构造大问题的最优解,因此需要最优子结构 8.请说明: (1)优先队列可用什么数据结构实现? (2)优先队列插入算法基本思5 想? (3)优先队列插入算法时间复杂度? 参
14、考解答: ( 1)堆。 (1 分 ) ( 2)在小根堆中,将元素 x 插入到堆的末尾, 然后将元素 x 的关键字与其双亲的关键字比较, 若元素 x 的关键字小于其双亲的关键字, 则将元素 x与其双亲交换,然后再将元素 x与其新双亲的关键字相比,直到元素 x 的关键字大于双亲的关键字,或元素 x 到根为止。 (4分 ) ( 3) O( log n)( 1 分) 9设计 动态规划算法的主要步骤 是怎么的?请简述。 参考解答: ( 1) 找出最优解的性质,并刻划其结构特征。 (6 分 ) ( 2)递归地定义最优值。 ( 3)以自底向上的方式计算出最优值。 ( 4)根据计算最优值时得到的信息,构造最优
15、解。 10.分治法所能解决的问题一般具有哪几个特征?请简述。 参考解答: ( 1)该问题的规模缩小到一定的程度就可以容易地解决; (6 分 ) ( 2)该问题可以分解为若干个规模较小的相同问题,即该问题具有最优子结 构性质 ; ( 3) 利用该问题分解出的子问题的解可以合并为该问题的解; ( 4) 原问题所分解出的各个子问题是相互独立的,即子问题之间不包含公共的子问题。 11.分支限界法的搜索策略是什么? 参考解答: 在扩展结点处,先生成其所有的儿子结点(分支),然后再从当前的活结点表中选择下一个扩展结点。为了有效地选择下一扩展结点,加速搜索的进程,在每一个活结点处,计算一个函数值(限界),并
16、根据函数值,从当前活结点表中选择一个最有利的结点作为扩展结点,使搜索朝着解空间上有最优解的分支推进,以便尽快地找出一个 最优解。 (6 分 ) 12 算法的要特性是什么? 参考解答: 确定性、可实现性、输入、输出、有穷性 13 算法分析的目的是什么? 参考解答: 分析算法占用计算机资源的情况,对算法做出比较和评价,设计出额更好的算法。 14 算法的时间复杂性与问题的什么因素相关? 参考解答: 算法的时间复杂性与问题的规模相关,是问题大小 n的函数。 15 算法的渐进时间复杂性的含义? 参考解答: 当问题的规模 n 趋向无穷大时,影响算法效率的重要因素是 T(n)的数量级,而其他因素仅是使时间复
17、杂度相差常数倍,因此可以用 T(n)的数量级6 (阶 )评价算法。时间复杂度 T(n)的数量级 (阶 )称为渐进时间复杂性。 16 最坏情况下的时间复杂性和平均时间复杂性有什么不同? 参考解答: 最坏情况下的时间复杂性和平均时间复杂性考察的是 n固定时,不同输入实例下的算法所耗时间。最坏情况下的时间复杂性取的输入实例中最大的时间复杂度: W(n) = max T(n, I) , I Dn 平均时间复杂性是所有输入实例的处理时间与各自概率的乘积和: A(n) = P(I)T(n, I) I Dn 17 简述二分检索(折半查找)算法的基本过程。 参考解答: 设输入是一个按非降次序排列的元素表 Ai
18、: j 和 x,选取 A(i+j)/2与 x比较,如果 A(i+j)/2=x,则返回 (i+j)/2,如果 A(i+j)/2= 当前最优解代价 bestf,则剪枝。 2分 ( 3)见( 1)中所画的图。 5分 ( 4)最优解为 3, 1, 2,最优值为 25。 3分 4.【 Gray码构造 问题】 ( 8分) 提示:此题 可采用分治递归算法实现 问题描述: “格雷码”是一个长度为 n2 的序列,满足: ( a)每个元素都是长度为 n比特的串 ( b)序列中无相同元素 ( c)连续的两个元素恰好只有 1个比特不同 例如: n=2时,格雷码为 00, 01, 11, 10。 Gray码是一种编码,
19、这种编码可以 避免在读取时,因各数据位时序上的差异造成的误读。格雷码在工程上有广泛应用。但格雷码不便于运算, 请你设计一种构造方法,输入长度序列 n,输出格雷码(你只要做出一种构造方案即可,格雷码并不唯一)。 参考解答: 此 题可用分治法解决。 当 n 1时,输出格雷码 0, 1 当 n1 时,格雷码的长度为 n2 ,即共有 n2 个码序列。此时,将问题一分为二,即上半部分和下半部分。上半部分最高位设为 0,下半部分最高位设为 1。剩下 n-1位的格雷码的构造采用递归的思路。 评分准则: 1) 答到使用分治算法,并且推导出分治算法的 过程 ,边界设定清晰 (即当仅输出 1位的格雷码如何处理)
20、,本题即可得满分; 2) 说明使用分治算法,但漏边界条件,扣 2分 以上 ; 2 1 1 3 2 3 1 2 3 1 3 2 3 V0 2 1 11 3 4 9 16 18 23 23 25 30 33 36 36 10 26 11 其它情况酌情考虑。 5.( 13 分 ) 给定带权有向图(如下图所示) G =(V,E),其中每条边的权是非负实数。另外,还给定 V中的一个顶点,称为源。现在要计算从源到所有其它各顶点的最短路长度。这里路的长度是指路上各边权之和。现采用 Dijkstra 算法计算从源顶点 1到其它顶点间最短路径。请将此过程填入下表中。 参考解答: ( 13分 ) 6.( 13分)
21、 有 0-1 背包问题如下: n=6, c=20, P=( 4, 8, 15, 1, 6, 3), W=( 5, 3, 2, 10, 4, 8)。 其中 n 为物品个数, c 为背包载重量, P 表示物 品的价值, W 表示物品的重量。请问对于此 0-1 背包问题,应如何选择放进去的物品,才能使到放进背包的物品总价值最大。 P=(15, 8, 6, 4, 3, 1) W=(2, 3, 4, 5, 8, 10),单位重量物品价值( 7.5, 2.67, 1.5,0.8,0.375,0.1) 参考解答: ( 13分 ) 可知随着物品的重量增加,物品的价值减少;因此可以用贪心算法来求解。以选取单位重
22、量物品价值高为贪心策略。 1.先把重量为 2的物品放进背包,此时剩余载重量为 17, P为 15。 2.把重量为 3的物品放进背包,此时剩余载重量为 14, P为 23; 3.把重量为 4的物品放进背包,此时剩余载重量为 10, P为 29; 4 3 2 1 1 初始 dist5 dist4 dist3 dist2 u S 迭代 60 30 50 10 5 1, 2, 3, 4, 5 4 60 30 50 10 3 1, 2, 4, 3 3 90 30 50 10 4 1, 2, 4 2 100 30 60 10 2 1, 2 1 100 30 10 - 1 初始 dist5 dist4 di
23、st3 dist2 u S 迭代 12 4.把重量为 5的物品放进背包,此时剩余载重量为 5, P为 33. 由于 85,所以不能再放进背包。 结果是把重量为 2, 3, 4, 5的物品装进背包,总价值最大为 33. 7、将所给定序列 a1:n分为长度相等的两段 a1:n/2和 an/2+1:n,分别求出这两段的最大子段和,则 a1:n的最大子段和有哪三种情形? (10 分 ) 参考解答: ( 1) a1:n的最大子段和与 a1:n/2的最大子段和相同。 ( 2) a1:n的最大 子段和与的最大子段 an/2+1:n和相同。 a1:n的最大子段和为 ak(i=k=J)且 1=i=n/2,n/2
24、+1=J=n。 8 写出 maxmin算法对下列实例中找最大数和最小数的过程。 数组 A=(48,12,61,3,5,19,32,7) 参考解答: 写出 maxmin算法对下列实例中找最大数和最小数的过程。 数组 A=() 1、 48,12,61,3, 5,19,32,7 2、 48,12 61,3 5,19 32,7 3、 48 61, 12 3 19 32, 5 7 4、 61 32 3 5 5、 61 3 9 速排序算法对下列实例排序,算法执行过程中,写出数组 A第一次被分割的过程。 A=(65,70,75,80,85,55,50,2) 参考解答: 第一个分割元素为 65 10 归并排序
25、算法对下列实例排序,写出算法执行过程。 A=(48,12,61,3,5,19,32,7) 参考解答: 48,12,61,3 5,19,32,7 48,12 61,3 5,19 32,7 12,48 3,61 5,19 7,32 3, 12, 48, 61 5, 7, 19, 32 3,5, 7,12, 19, 32, 48,61 (1) (2) (3) (4) (5) (6) (7) (8) i p 65 70 75 80 85 55 50 2 2 8 65 2 75 80 85 55 50 70 3 7 65 2 50 80 85 55 75 70 4 6 65 2 50 55 85 80 75 70 4 6 55 70 75 80 85 65 50 2