算法设计与分析资料报告复习题目及问题详解1

上传人:沈*** 文档编号:101025623 上传时间:2022-06-04 格式:DOC 页数:22 大小:443.50KB
收藏 版权申诉 举报 下载
算法设计与分析资料报告复习题目及问题详解1_第1页
第1页 / 共22页
算法设计与分析资料报告复习题目及问题详解1_第2页
第2页 / 共22页
算法设计与分析资料报告复习题目及问题详解1_第3页
第3页 / 共22页
资源描述:

《算法设计与分析资料报告复习题目及问题详解1》由会员分享,可在线阅读,更多相关《算法设计与分析资料报告复习题目及问题详解1(22页珍藏版)》请在装配图网上搜索。

1、 一、选择题1、二分搜索算法是利用(A )实现的算法。A、分治策略 B、动态规划法 C、贪心法 D、回溯法2、下列不是动态规划算法基本步骤的是(A )。A、找出最优解的性质B、构造最优解 C、算出最优解 D、定义最优解3、最大效益优先是(A )的搜索方式。A、分支界限法 B、动态规划法 C、贪心法 D、回溯法4. 回溯法解旅行售货员问题时的解空间树是(B)。A、子集树B、排列树C、深度优先生成树D、广度优先生成树5下列算法常以自底向上的方式求解最优解的是(B )。A、备忘录法B、动态规划法C、贪心法D、回溯法6、衡量一个算法好坏的标准是(C )。A 运行速度快 B 占用空间少 C 时间复杂度低

2、 D 代码短7、以下不可以使用分治法求解的是(D )。A 棋盘覆盖问题 B 选择问题 C 归并排序 D 0/1背包问题8. 实现循环赛日程表利用的算法是(A )。A、分治策略B、动态规划法C、贪心法D、回溯法9下面不是分支界限法搜索方式的是(D )。A、广度优先B、最小耗费优先C、最大效益优先D、深度优先10下列算法常以深度优先方式系统搜索问题解的是(D )。A、备忘录法B、动态规划法C、贪心法D、回溯法11.备忘录方法是那种算法的变形。( B )A、分治法B、动态规划法C、贪心法D、回溯法12哈弗曼编码的贪心算法所需的计算时间为(B )。A、O(n2n)B、O(nlogn)C、O(2n)D、

3、O(n)13分支限界法解最大团问题时,活结点表的组织形式是(B )。A、最小堆B、最大堆 C、栈D、数组14最长公共子序列算法利用的算法是(B )。A、分支界限法B、动态规划法C、贪心法D、回溯法15实现棋盘覆盖算法利用的算法是(A )。A、分治法B、动态规划法C、贪心法D、回溯法16.下面是贪心算法的基本要素的是(C )。A、重叠子问题B、构造最优解C、贪心选择性质D、定义最优解17.回溯法的效率不依赖于下列哪些因素( D )A. 满足显约束的值的个数 B. 计算约束函数的时间 C. 计算限界函数的时间 D. 确定解空间的时间18.下面哪种函数是回溯法中为避免无效搜索采取的策略(B )19、

4、下面关于NP问题说确的是(B )A NP问题都是不可能解决的问题B P类问题包含在NP类问题中C NP完全问题是P类问题的子集D NP类问题包含在P类问题中20蒙特卡罗算法是(B )的一种。A、分支界限算法B、概率算法 C、贪心算法D、回溯算法21.(D )是贪心算法与动态规划算法的共同点。A、重叠子问题B、构造最优解C、贪心选择性质D、最优子结构性质22. 矩阵连乘问题的算法可由(B)设计实现。A、分支界限算法B、动态规划算法C、贪心算法 D、回溯算法23. 分支限界法解旅行售货员问题时,活结点表的组织形式是(A )。A、最小堆B、最大堆 C、栈D、数组24、Strassen矩阵乘法是利用(

5、A )实现的算法。A、分治策略 B、动态规划法 C、贪心法 D、回溯法25、使用分治法求解不需要满足的条件是(A )。A 子问题必须是一样的B 子问题不能够重复C 子问题的解可以合并D 原问题和子问题使用相同的方法解26、下面问题(B )不能使用贪心法解决。A 单源最短路径问题 B N皇后问题 C 最小花费生成树问题 D 背包问题27、下列算法中不能解决0/1背包问题的是(A )A 贪心法 B 动态规划 C 回溯法 D 分支限界法28、回溯法搜索状态空间树是按照(C )的顺序。A 中序遍历 B 广度优先遍历 C 深度优先遍历 D 层次优先遍历29实现合并排序利用的算法是(A )。A、分治策略B

6、、动态规划法C、贪心法D、回溯法30下列是动态规划算法基本要素的是(D )。A、定义最优解B、构造最优解C、算出最优解D、子问题重叠性质31下列算法常以自底向下的方式求解最优解的是(B )。A、分治法B、动态规划法C、贪心法D、回溯法32采用广度优先策略搜索的算法是(A )。A、分支界限法B、动态规划法C、贪心法D、回溯法33、合并排序算法是利用(A)实现的算法。A、分治策略 B、动态规划法 C、贪心法 D、回溯法34、背包问题的贪心算法所需的计算时间为(B )A、O(n2n) B、O(nlogn) C、O(2n)D、O(n)35实现大整数的乘法是利用的算法(C )。A、贪心法B、动态规划法C

7、、分治策略D、回溯法360-1背包问题的回溯算法所需的计算时间为(A )A、O(n2n)B、O(nlogn)C、O(2n)D、O(n)37采用最大效益优先搜索方式的算法是(A )。A、分支界限法B、动态规划法C、贪心法D、回溯法38贪心算法与动态规划算法的主要区别是(B )。A、最优子结构B、贪心选择性质C、构造最优解D、定义最优解39. 实现最大子段和利用的算法是(B )。A、分治策略B、动态规划法C、贪心法D、回溯法40.优先队列式分支限界法选取扩展结点的原则是(C )。A、先进先出B、后进先出C、结点的优先级D、随机41.背包问题的贪心算法所需的计算时间为(B )。A、O(n2n)B、O

8、(nlogn)C、O(2n)D、O(n)42、广度优先是(A )的搜索方式。A、分支界限法 B、动态规划法C、贪心法 D、回溯法43下列哪一种算法是随机化算法(D )44. 一个问题可用动态规划算法或贪心算法求解的关键特征是问题的(B )。A、重叠子问题B、最优子结构性质C、贪心选择性质D、定义最优解45采用贪心算法的最优装载问题的主要计算量在于将集装箱依其重量从小到大排序,故算法的时间复杂度为 (B ) 。A、O(n2n)B、O(nlogn)C、O(2n)D、O(n)46. 以深度优先方式系统搜索问题解的算法称为( D ) 。A、分支界限算法B、概率算法C、贪心算法 D、回溯算法47. 实现

9、最长公共子序列利用的算法是(B )。A、分治策略B、动态规划法C、贪心法D、回溯法48、算法是由若干条指令组成的有穷序列,而且满足以下性质( D)(1) 输入:有0个或多个输入(2) 输出:至少有一个输出(3) 确定性:指令清晰,无歧义(4) 有限性:指令执行次数有限,而且执行时间有限 A (1)(2)(3) B(1)(2)(4) C(1)(3)(4) D (1) (2)(3)(4)48、函数32n+10nlogn的渐进表达式是( B ).A. 2nB. 32nC. nlognD. 10nlogn252、设f(N),g(N)是定义在正数集上的正函数,如果存在正的常数C和自然数N0,使得当NN0

10、时有f(N)Cg(N),则称函数f(N)当N充分大时有下界g(N),记作f(N)二、 填空题 时间 复杂性和 空间 复杂性之分。2、程序是 算法 用某种程序设计语言的具体实现。3、算法的“确定性”指的是组成算法的每条 指令 是清晰的,无歧义的。 动态规划 设计实现。5、算法是指解决问题的 一种方法 或 一个过程 。6、从分治法的一般设计模式可以看出,用它设计出的程序一般是递归算法 。7、问题的 最优子结构性质 是该问题可用动态规划算法或贪心算法求解的关键特征。8、以深度优先方式系统搜索问题解的算法称为 回溯法 。9、数值概率算法常用于 数值问题 的求解。10、计算一个算法时间复杂度通常可以计算

11、循环次数 、基本操作的频率或计算步。11、利用概率的性质计算近似值的随机算法是_数值概率算法,运行时以一定的概率得到正确解的随机算法是_蒙特卡罗算法_。12、解决0/1背包问题可以使用动态规划、回溯法和分支限界法,其中不需要排序的是动态规划,需要排序的是回溯法,分支限界法。13、使用回溯法进行状态空间树裁剪分支时一般有两个标准:约束条件和目标函数的界,N皇后问题和0/1背包问题正好是两种不同的类型,其中同时使用约束条件和目标函数的界进行裁剪的是0/1背包问题,只使用约束条件进行裁剪的是N皇后问题。14、 贪心选择性质 是贪心算法可行的第一个基本要素,也是贪心算法与动态规划算法的主要区别。15、

12、矩阵连乘问题的算法可由 动态规划 设计实现。 贪心选择 性质和 最优子结构 性质 。17. 动态规划算法的基本思想是将待求解问题分解成若干子问题,先求解 子问题 ,然后从这些 子问题 的解得到原问题的解。18.算法是由若干条指令组成的有穷序列,且要满足输入、 输出 、确定性和 有限性 四条性质。19、大整数乘积算法是用 分治法 来设计的。20、以广度优先或以最小耗费方式搜索问题解的算法称为 分支限界法 。21、 贪心选择性质 是贪心算法可行的第一个基本要素,也是贪心算法与动态规划算法的主要区别。22.快速排序算法是基于 分治策略 的一种排序算法。最优子结构性质和重叠子问题 性质 。24.回溯法

13、是一种既带有 系统性又带有 跳跃性的搜索算法。 队列式(FIFO)分支限界法和 优先队列式分支限界法。26分支限界法是一种既带有系统性又带有跳跃性 的搜索算法。27回溯法搜索解空间树时,常用的两种剪枝函数为约束函数 和限界函数。 规模 有关。 划分的对称性 。30. Prim算法利用贪心策略求解最小生成树问题,其时间复杂度是 O(n2)。31. 图的m着色问题可用 回溯法求解,其解空间树中叶子结点个数是mn,解空间树中每个结点的孩子数是 m。22 / 22三、算法填空void Knapsack(int n,float M,float v,float w,float x) Sort(n,v,w)

14、; 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.最大子段和: 动态规划算法int MaxSum(int n, int a) int sum=0, b=0; /sum存储当前最大的bj, b存储bj for(int j=1; j0) b+= aj ;else b=ai; ; /一旦某个区段和为负,则从下一个位置累和 if(bsum) sum=b; return sum; templatevoid QuickSort (Type a, int p, in

15、t r) if (pr) int q=Partition(a,p,r);QuickSort (a,p,q-1); /对左半段排序 QuickSort (a,q+1,r); /对右半段排序 Template void perm(Type list, int k, int m ) /产生listk:m的所有排列 if(k=m) /只剩下一个元素 for (int i=0;i=m;i+) coutlisti; coutendl; else /还有多个元素待排列,递归产生排列 for (int i=k; i=m; i+) swap(listk,listi);perm(list,k+1;m); swap

16、(listk,listi); 5.给定已按升序排好序的n个元素a0:n-1,现要在这n个元素中找出一特定元素x。据此容易设计出二分搜索算法:template int BinarySearch(Type a, const Type& x, int l, int r) while (l=r) int m = (l+r)/2); if (x = am) return m; if (x am) r = m-1; else l = m+1; return -1; 6、合并排序描述如下:templatevoid Mergesort(Type a , int left, int right)if (left

17、0) y=y*x; (return y);四、问答题1.用计算机求解问题的步骤:1、问题分析2、数学模型建立3、算法设计与选择4、算法指标5、算法分析6、算法实现7、程序调试8、结果整理文档编制2. 算法定义:算法是指在解决问题时,按照某种机械步骤一定可以得到问题结果的处理过程(1)操作(2)控制结构(3)数据结构4. 算法具有以下5个属性:有穷性:一个算法必须总是在执行有穷步之后结束,且每一步都在有穷时间完成。确定性:算法中每一条指令必须有确切的含义。不存在二义性。只有一个入口和一个出口可行性:一个算法是可行的就是算法描述的操作是可以通过已经实现的基本运算执行有限次来实现的。输入:一个算法有

18、零个或多个输入,这些输入取自于某个特定对象的集合。输出:一个算法有一个或多个输出,这些输出同输入有着某些特定关系的量。5. 算法设计的质量指标:正确性:算法应满足具体问题的需求;可读性:算法应该好读,以有利于读者对程序的理解;健壮性:算法应具有容错处理,当输入为非法数据时,算法应对其作出反应,而不是产生莫名其妙的输出结果。效率与存储量需求:效率指的是算法执行的时间;存储量需求指算法执行过程中所需要的最大存储空间。一般这两者与问题的规模有关。经常采用的算法主要有迭代法、分治法、贪婪法、动态规划法、回溯法、分支限界法6. 迭代法: 也称“辗转法”,是一种不断用变量的旧值递推出新值的解决问题的方法。

19、7.利用迭代算法解决问题,需要做好以下三个方面的工作:1)、确定迭代模型。在可以用迭代算法解决的问题中,至少存在一个直接或间接地不断由旧值递推出新值的变量,这个变量就是迭代变量。2)、建立迭代关系式。所谓迭代关系式,指如何从变量的前一个值推出其下一个值的公式(或关系)。迭代关系式的建立是解决迭代问题的关键,通常可以使用递推或倒推的方法来完成。3)、对迭代过程进行控制。在什么时候结束迭代过程?这是编写迭代程序必须考虑的问题。不能让迭代过程无休止地重复执行下去。迭代过程的控制通常可分为两种情况:一种是所需的迭代次数是个确定的值,可以计算出来;另一种是所需的迭代次数无法确定。对于前一种情况,可以构建

20、一个固定次数的循环来实现对迭代过程的控制;对于后一种情况,需要进一步分析出用来结束迭代过程的条件。8.分治法的基本思想是:将一个规模为n的问题分解为k个规模较小的子问题,这些子问题互相独立且与原问题相同。递归地解这些子问题,然后将各个子问题的解合并得到原问题的解。9.分治法所能解决的问题一般具有以下几个特征: (1)该问题的规模缩小到一定的程度就可以容易地解决; (2)该问题可以分解为若干个规模较小的相同问题,即该问题具有最优子结构性质; (3)利用该问题分解出的子问题的解可以合并为该问题的解; (4)该问题所分解出的各个子问题是相互独立的,即子问题之间不包含公共的子问题。 10、分治法的基本

21、步骤 分治法在每一层递归上都有三个步骤: (1)分解:将原问题分解为若干个规模较小,相互独立,与原问题形式相同的子问题; (2)解决:若子问题规模较小而容易被解决则直接解,否则递归地解各个子问题; (3)合并:将各个子问题的解合并为原问题的解。11. 动态规划的基本思想前文主要介绍了动态规划的一些理论依据,我们将前文所说的具有明显的阶段划分和状态转移方程的动态规划称为标准动态规划,这种标准动态规划是在研究多阶段决策问题时推导出来的,具有严格的数学形式,适合用于理论上的分析。在实际应用中,许多问题的阶段划分并不明显,这时如果刻意地划分阶段法反而麻烦。一般来说,只要该问题可以划分成规模更小的子问题

22、,并且原问题的最优解中包含了子问题的最优解(即满足最优子化原理),则可以考虑用动态规划解决。动态规划的实质是分治思想和解决冗余,因此,动态规划是一种将问题实例分解为更小的、相似的子问题,并存储子问题的解而避免计算重复的子问题,以解决最优化问题的算法策略。由此可知,动态规划法与分治法和贪心法类似,它们都是将问题实例归纳为更小的、相似的子问题,并通过求解子问题产生一个全局最优解。贪心法的当前选择可能要依赖已经作出的所有选择,但不依赖于有待于做出的选择和子问题。因此贪心法自顶向下,一步一步地作出贪心选择;而分治法中的各个子问题是独立的(即不包含公共的子问题),因此一旦递归地求出各子问题的解后,便可自

23、下而上地将子问题的解合并成问题的解。不足之处:如果当前选择可能要依赖子问题的解时,则难以通过局部的贪心策略达到全局最优解;如果各子问题是不独立的,则分治法要做许多不必要的工作,重复地解公共的子问题。解决上述问题的办法是利用动态规划。该方法主要应用于最优化问题,这类问题会有多种可能的解,每个解都有一个值,而动态规划找出其中最优(最大或最小)值的解。若存在若干个取最优值的解的话,它只取其中的一个。在求解过程中,该方法也是通过求解局部子问题的解达到全局最优解,但与分治法和贪心法不同的是,动态规划允许这些子问题不独立,(亦即各子问题可包含公共的子问题)也允许其通过自身子问题的解作出选择,该方法对每一个

24、子问题只解一次,并将结果保存起来,避免每次碰到时都要重复计算。因此,动态规划法所针对的问题有一个显著的特征,即它所对应的子问题树中的子问题呈现大量的重复。动态规划法的关键就在于,对于重复出现的子问题,只在第一次遇到时加以求解,并把答案保存起来,让以后再遇到时直接引用,不必重新求解。12、动态规划算法的基本步骤设计一个标准的动态规划算法,通常可按以下几个步骤进行:(1)划分阶段:按照问题的时间或空间特征,把问题分为若干个阶段。注意这若干个阶段一定要是有序的或者是可排序的(即无后向性),否则问题就无法用动态规划求解。 (2)选择状态:将问题发展到各个阶段时所处于的各种客观情况用不同的状态表示出来。

25、当然,状态的选择要满足无后效性。 (3)确定决策并写出状态转移方程:之所以把这两步放在一起,是因为决策和状态转移有着天然的联系,状态转移就是根据上一阶段的状态和决策来导出本阶段的状态。所以,如果我们确定了决策,状态转移方程也就写出来了。但事实上,我们常常是反过来做,根据相邻两段的各状态之间的关系来确定决策。 (4)写出规划方程(包括边界条件):动态规划的基本方程是规划方程的通用形式化表达式。一般说来,只要阶段、状态、决策和状态转移确定了,这一步还是比较简单的。动态规划的主要难点在于理论上的设计,一旦设计完成,实现部分就会非常简单。根据动态规划的基本方程可以直接递归计算最优值,但是一般将其改为递

26、推计算。实际应用当中经常不显式地按照上面步骤设计动态规划,而是按以下几个步骤进行:(1)分析最优解的性质,并刻划其结构特征。 (2)递归地定义最优值。 (3)以自底向上的方式或自顶向下的记忆化方法(备忘录法)计算出最优值。 (4)根据计算最优值时得到的信息,构造一个最优解。 步骤(1)(3)是动态规划算法的基本步骤。在只需要求出最优值的情形,步骤(4)可以省略,若需要求出问题的一个最优解,则必须执行步骤(4)。此时,在步骤(3)中计算最优值时,通常需记录更多的信息,以便在步骤(4)中,根据所记录的信息,快速地构造出一个最优解。总结:动态规划实际上就是最优化的问题,是指将原问题的大实例等价于同一

27、最优化问题的较小实例,自底向上的求解最小实例,并将所求解存放起来,存放的结果就是为了准备数据。与递归相比,递归是不断的调用子程序求解,是自顶向下的调用和求解。13. 分治法与动态规划法的相同点是:将待求解的问题分解成若干个子问题,先求解子问题,然后从这些子问题的解得到原问题的解。两者的不同点是:适合于用动态规划法求解的问题,经分解得到的子问题往往不是互相独立的。而用分治法求解的问题,经分解得到的子问题往往是互相独立的。14. 回溯法回溯法也称为试探法,该方法首先暂时放弃关于问题规模大小的限制,并将问题的候选解按某种顺序逐一枚举和检验。当发现当前候选解不可能是解时,就选择下一个候选解;倘若当前候

28、选解除了还不满足问题规模要求外,满足所有其他要求时,继续扩大当前候选解的规模,并继续试探。如果当前候选解满足包括问题规模在的所有要求时,该候选解就是问题的一个解。在回溯法中,放弃当前候选解,寻找下一个候选解的过程称为回溯。扩大当前候选解的规模,以继续试探的过程称为向前试探。15. 分支限界法:这是一种用于求解组合优化问题的排除非解的搜索算法。类似于回溯法,分枝定界法在搜索解空间时,也经常使用树形结构来组织解空间。然而与回溯法不同的是,回溯算法使用深度优先方法搜索树结构,而分枝定界一般用宽度优先或最小耗费方法来搜索这些树。因此,可以很容易比较回溯法与分枝定界法的异同。相对而言,分枝定界算法的解空

29、间比回溯法大得多,因此当存容量有限时,回溯法成功的可能性更大。算法思想:分枝限界(branch and bound)是另一种系统地搜索解空间的方法,它与回溯法的主要区别在于对E-节点的扩充方式。每个活节点有且仅有一次机会变成E-节点。当一个节点变为E-节点时,则生成从该节点移动一步即可到达的所有新节点。在生成的节点中,抛弃那些不可能导出(最优)可行解的节点,其余节点加入活节点表,然后从表中选择一个节点作为下一个E-节点。从活节点表中取出所选择的节点并进行扩充,直到找到解或活动表为空,扩充过程才结束。有两种常用的方法可用来选择下一个E-节点(虽然也可能存在其他的方法):1) 先进先出(F I F

30、 O)即从活节点表中取出节点的顺序与加入节点的顺序相同,因此活节点表的性质与队列相同。2) (优先队列)最小耗费或最大收益法在这种模式中,每个节点都有一个对应的耗费或收益。如果查找一个具有最小耗费的解,则活节点表可用最小堆来建立,下一个E-节点就是具有最小耗费的活节点;如果希望搜索一个具有最大收益的解,则可用最大堆来构造活节点表,下一个 E-节点是具有最大收益的活节点16. 分支限界法与回溯法的相同点是:都是一种在问题的解空间树T中搜索问题解的算法。不同点:(1)求解目标不同; (2)搜索方式不同; (3)对扩展结点的扩展方式不同; (4)存储空间的要求不同。17.分治法所能解决的问题一般具有

31、的几个特征是:(1)该问题的规模缩小到一定的程度就可以容易地解决;(2)该问题可以分解为若干个规模较小的相同问题,即该问题具有最优子结构性质;(3)利用该问题分解出的子问题的解可以合并为该问题的解;(4)原问题所分解出的各个子问题是相互独立的,即子问题之间不包含公共的子问题。18.用分支限界法设计算法的步骤是:(1)针对所给问题,定义问题的解空间(对解进行编码); (2)确定易于搜索的解空间结构(按树或图组织解) ; (3)以广度优先或以最小耗费(最大收益)优先的方式搜索解空间,并在搜索过程中用剪枝函数避免无效搜索。19. 常见的两种分支限界法的算法框架:(1)队列式(FIFO)分支限界法:按

32、照队列先进先出(FIFO)原则选取下一个节点为扩展节点。 (2)优先队列式分支限界法:按照优先队列中规定的优先级选取优先级最高的节点成为当前扩展节点。20. 回溯法中常见的两类典型的解空间树是子集树和排列树。当所给的问题是从n个元素的集合S中找出满足某种性质的子集时,相应的解空间树称为子集树。这类子集树通常有2n个叶结点,遍历子集树需O(2n)计算时间 。当所给的问题是确定n个元素满足某种性质的排列时,相应的解空间树称为排列树。这类排列树通常有n!个叶结点。遍历排列树需要O(n!)计算时间。21. 分支限界法的搜索策略是: 在扩展结点处,先生成其所有的儿子结点(分支),然后再从当前的活结点表中

33、选择下一个扩展结点。为了有效地选择下一扩展结点,加速搜索的进程,在每一个活结点处,计算一个函数值(限界),并根据函数值,从当前活结点表中选择一个最有利的结点作为扩展结点,使搜索朝着解空间上有最优解的分支推进,以便尽快地找出一个最优解。22. 请叙述动态规划算法与贪心算法的异同。共同点:都需要最优子结构性质,都用来求有优化问题。不同点:动态规划:每一步作一个选择依赖于子问题的解。 贪心方法:每一步作一个选择不依赖于子问题的解。动态规划方法的条件:子问题的重叠性质。可用贪心方法的条件:最优子结构性质;贪心选择性质。动态规划:自底向上求解; 贪心方法: 自顶向下求解。可用贪心法时,动态规划方法可能不

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

35、相比,直到元素x的关键字大于双亲的关键字,或元素x到根为止。(3)O( log n)25. 衡量算法时间效率的方法有哪两种?请叙述。答:有事前分析法和事后分析法两种。事后分析法:先将算法用程序设计语言实现,然后度量程序的运行时间。事前分析法:算法的时间效率是问题规模的函数,假如,随着问题规模n的增长,算法执行时间的增长率和函数f(n)的增长率相同,则可记作: T(n)=(f(n)称T(n)为算法的渐进时间复杂度。简称时间复杂度。26. 在算法复杂性分析中,O、这三个记号的意义是什么?在忽略常数因子的情况下,O、分别提供了算法运行时间的什么界?答:如果存在两个正常数c和N0,对于所有的NN0,有

36、|f(N)|C|g(N)|,则记作:f(N)= O(g(N)。这时我们说f(N)的阶不高于g(N)的阶。若存在两个正常数C和自然数N0,使得当NN0时有|f(N)|C|g(N)|,记为f(N)=(g(N)。这时我们说f(N)的阶不低于g(N)的阶。如果存在正常数c1,c2和n0,对于所有的nn0,有c1|g(N)| |f(N)| c2|g(N)|则记作f(N)= (g,(N)O、分别提供了算法运行时间的上界、下界、平均五、算法设计与分析题1用动态规划策略求解最长公共子序列问题: (1)给出计算最优值的递归方程。 (2)给定两个序列X=B,C,D,A,Y=A,B,C,B,请采用动态规划策略求出其

37、最长公共子序列,要求给出过程。答:(1) (2)0 0 0 00 0 1 1 10 0 1 2 20 0 1 2 20 1 1 2 2 最长公共子序列:2对下列各组函数f (n) 和g (n),确定f (n) = O (g (n) 或f (n) =(g (n)或f(n) =(g(n),并简要说明理由。(1) f(n)=2n;g(n)=n! (2) f(n)=; g (n)=log n2(3) f(n)=100; g(n)=log100 (4) f(n)=n3; g(n)= 3n(5) f(n)=3n;g(n)=2n答: (1) f(n) = O(g(n) 因为g(n)的阶比f(n)的阶高。(2

38、) f(n) = (g(n) 因为g(n)的阶比f(n)的阶低。(3) f(n) =(g(n) 因为g(n)与f(n)同阶。(4) f(n) = O(g(n) 因为g(n)的阶比f(n)的阶高。(5) f(n) = (g(n) 因为g(n)的阶比f(n)的阶低。3对下图所示的连通网络G,用克鲁斯卡尔(Kruskal)算法求G的最小生成树T,请写出在算法执行过程中,依次加入T的边集TE中的边。说明该算法的贪心策略和算法的基本思想,并简要分析算法的时间复杂度。12345618111715192126679答:TE=(3,4), (2,3),(1,5),(4,6)(4,5) 贪心策略是每次都在连接两

39、个不同连通分量的边中选权值最小的边。基本思想:首先将图中所有顶点都放到生成树中,然后每次都在连接两个不同连通分量的边中选权值最小的边,将其放入生成树中,直到生成树中有n-1条边。时间复杂度为:O(eloge) 4. 请用分治策略设计递归的归并排序算法,并分析其时间复杂性(要求:分别给出divide、conquer、bine这三个阶段所花的时间,并在此基础上列出递归方程,最后用套用公式法求出其解的渐进阶)。答 : Template void MergeSort (Type a , int left, int right) if (left2);T(2)=1。因为n=2 k(k 为正整数),所以,

40、T(n)= T(2 k)= 2T(2 k-1)+2= 22T(2 k-2)+ 22+2.= 2k-1T(2)+ 2k-2+.+23+22+2= 2k-1+.+23+22+2。因此,T(n)=Q(n)。8.考虑使用动态规划方法求解下列问题:01背包数据如下表,求:能够放入背包的最有价值的物品集合。物品i重量 wi价值 vi承重量 W1w1=2v1=12W=52w2=1v2=103w3=3v3=204w4=2v4=15如设: V(i, j) 前 i 个物品中能够装入承重量 j 的背包中的最大总价值。请将如下递推式填写完整:V(0, j) = 0(0个物品),V(i, 0) = 0(承重量0) V(

41、i, j) = V(i-1, j) 第 i 个物品不能装入, j wi (不超重) i在最优子集中 i不在最优子集中自底向上:按行或列填写下表。Vj=012345i=000000010203040答: V(0, j) = 0(0个物品),V(i, 0) = 0(承重量0)V(i, j) = V(i-1, j) 第 i 个物品不能装入, j wi (不超重) i在最优子集中 i不在最优子集中Vj=012345i=000000010012121212201012222222301012223032401015253037用回溯法解4皇后问题的解空间树和搜索空间树:解空间树:用回溯法的搜索空间树:给

42、定n种物品和一背包。物品i的重量是wi,其价值为vi,背包的容量为C。问应如何选择装入背包的物品,使得装入背包中物品的总价值最大?示例:n=3, C=30, w=16, 15, 15, v=45, 25, 25求:1、问题的解空间树 2、约束条件2、如何剪枝?解:问题的解空间树:约束条件:如何剪枝?: 设r是当前尚未考虑的剩余物品价值总和;Cv是当前价值;bestv是当前最优价值。当rCvbestv时,可剪去右子树。11,请画出用回溯法解n=3的0-1背包问题的解空间树和当三个物品的重量为20, 15, 10,价值为20, 30, 25,背包容量为25时搜索空间树。答:解空间树:1111110

43、000000112345781112141531069搜索空间树:1不可行解价值=20价值=55价值=30价值=25价值=01111000000112811121415131069算法设计与分析复习(2015)考试题型与围1.单选题、判断题、填空题、简答题、分析题、计算题。第1章 算法设计与分析基础1、 算法概念、特征、与程序的区别2、 问题、问题求解、问题求解过程(理解问题、设计方案、实现方案、回顾复查)、系统生命周期(分析、设计、编码、维护)3、 算法问题求解过程(设计、表示、确认、分析)4、 好的算法特性(正确性、简明性、效率、最优性)5、 影响运行时间的因素(3点)6、 算法复杂度、时

44、间复杂度、空间复杂度、最好、最坏和平均时间复杂度7、 渐进表示法:大O记号、记号、记号8、 算法按时间复杂度分类:多项式时间算法和指数时间算法 O(1)O(logn)O(nlogn)O(n2)O(n3)O(2n)O(n! )O(nn)9、 了解非递归算法的时间复杂性分析。要点:对非递归算法时间复杂性的分析,关键是建立一个代表算法运行时间的求和表达式,然后用渐进符号表示这个求和表达式。非递归算法分析的一般步骤是:(1)决定用哪个(或哪些)参数作为算法问题规模的度量。(2)找出算法的基本语句。(3)检查基本语句的执行次数是否只依赖问题规模。(4)建立基本语句执行次数的求和表达式。(5)用渐进符号表

45、示这个求和表达式。10、 常见的重要问题类型排序问题、查找问题、图问题、组合问题、几何问题、数值问题其他问题11、 常用的基本数据结构 线性结构:栈、队列、数组 非线性:树、图12、 常用的算法设计方法 数值计算方法:迭代法、插值法、差分法、归纳法、递推法、减半递推技术、递归法 非数值计算方法:列举法分治法、贪心法、动态规划法、回溯法、分支限界法13、 递归、递归算法、递归设计结构、归纳证明第2章 递归法1、 递归算法特性、执行过程2、 递推关系分析算法复杂度3、 计算递推式三种方法:替换方法、迭代方法、主方法4、 掌握扩展递归技术和通用分治递推式的使用。扩展递归技术:通用分支递归式:第3章

46、分治法1、设计思想:将要求解的原问题划分成k个较小规模的子问题,对这k个子问题分别求解。如果子问题的规模仍然不够小,则再将每个子问题划分为k个规模更小的子问题,如此分解下去,直到问题规模足够小,很容易求出其解为止,再将子问题的解合并为一个更大规模的问题的解,自底向上逐步求出原问题的解。2、步骤:(1)划分(2)求解子问题(3)合并3、分治法的代表算法及时间复杂度:排序问题(归并排序、快速排序)O(nlogn),折半查找 O(logn)、选择问题O(n),最大子段和O(n3)、棋盘覆盖问题O(4k)第4章 贪心法1、可行解、最优解、最优量度标准、可行解判断函数2、设计思想贪心法在解决问题的策略上

47、目光短浅,只根据当前已有的信息就做出局部最优选择,而且一旦做出了选择,不管将来有什么结果,这个选择都不会改变。3、贪心法的关键在于决定贪心策略。4、贪心法两个基本要素:最优子结构性质和贪心选择性质5、贪心法解决的问题(可求最优解):背包问题,活动安排问题,多机调度问题,单源最短路径,最小代价生成树的两种贪心算法:prim算法和kruskal算法。第5章 动态规划法1、设计思想:将待求解问题分解成若干个相互重叠的子问题,每个子问题对应决策过程的一个阶段,将子问题的解求解一次并填入表中,当需要再次求解此子问题时,可以通过查表获得该子问题的解而不用再次求解。2、步骤:(1)刻画最优解的结构特性;(2

48、)递归定义最优解值;(3)以自底向上方式计算最优解;(4)根据计算得到的信息构造一个最优解。3、两个要素:最优子结构性质和子问题重叠性质4、动态规划法解决的问题(可求最优解):多段图问题(n+e),每对结点间的最短路径O(n3)最长公共子序列,最优二叉搜索树O(n3),0/1背包问题O(2n),流水作业调度O(nlogn)。第6章 回溯法1、 设计思想:从解空间树根结点出发,按照深度优先策略遍历解空间树,在搜索至树中任一结点时,先判断该结点对应的部分解是否满足约束条件,或者是否超出目标函数的界,也就是判断该结点是否包含问题的(最优)解,如果肯定不包含,则跳过对以该结点为根的子树的搜索,即所谓剪

49、枝(Pruning);否则,进入以该结点为根的子树,继续按照深度优先策略搜索。直到搜索到叶子结点,则得到问题的一个可能解。2、 显约束、隐约束、解状态、约束函数、剪枝函数等3、步骤:(1)针对所给问题,定义问题的解空间;(2)确定易于搜索的解空间结构;(3)按深度优先方式搜索解空间,且在搜索过程中利用剪枝函数避免无效搜索。从所有的可能解中确定最优解。4、回溯法解决的问题(可求所有解、一个解、最优解):属于组合问题和排列问题中求最优解的问题都可以用回溯法解决,例如:八皇后问题(4皇后问题),0/1背包问题,子集合和数,图着色问题,TSP问题,深度优先搜索。第7章 分支限界法1、设计思想:1)首先

50、确定一个合理的限界函数,并根据限界函数确定目标函数的界down, up ,并确定限界函数;2)然后按照广度优先策略遍历问题的解空间树,在分支结点上,依次搜索该结点的所有孩子结点,分别估算这些孩子结点的限界函数的可能取值;3)如果某孩子结点的限界函数可能取得的值超出目标函数的界,则将其丢弃;否则,将其加入待处理结点表(以下简称表PT)中;4)依次从表PT中选取使限界函数的值是极值的结点成为当前扩展结点;5)重复上述过程,直到找到搜索到叶子结点,如果叶子结点的限界函数的值是极值,则就是问题的最优解,否则,找到其他极值结点重复扩展搜索。2、步骤:确定解空间树确定限界函数按广度优先搜索解空间树,计算限界函数的值,填入PT表从PT表中寻找极值,继续扩展结点,直到找到限界函数值为极值的叶子结点。3、使用分支限界法解决的问题(可求最优解):带时限的作业排序、TSP问题,批处理作业调度问题,0/1背包问题。

展开阅读全文
温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!