算法设计与分析复习题整理 (1)
《算法设计与分析》复习题

填空1.直接或间接地调用自身的算法称为 递归 。
2.算法的复杂性是 算法效率 的度量,是评价算法优劣的重要依据。
3.以广度优先或以最小耗费方式搜索问题解的算法称为 分支限界法。
4.回溯法解题的显著特点是在搜索过程中动态产生问题的解空间。
在任何时刻,算法只保存从根结点到当前扩展结点的路径。
如果解空间树中从根结点到叶结点的最长路径的长度为h(n),则回溯法所需的计算空间通常为 o(h(n)) 。
5.人们通常将问题的解决方案分为两大类:一类是可以通过执行若干个步骤就能得出问题6.算法就是一组有穷的 规则 ,它们规定了解决某一特定类型问题的 一系列运算 。
7.在进行问题的计算复杂性分析之前,首先必须建立求解问题所用的计算模型。
3个基本计算模型是 随机存取机、 随机存取存储程序机 、 图灵机 。
8.快速排序算法的性能取决于 划分的对称性 。
9.计算机的资源最重要的是 内存 和 运算 资源。
因而,算法的复杂性有时间 和 空间 之分。
10.贪心算法总是做出在当前看来 最优 的选择。
也就是说贪心算法并不从整体最优考虑,它所做出的选择只是在某种意义上的 局部最优解 。
11.许多可以用贪心算法求解的问题一般具有2个重要的性质: 最优子结构的 性质和 贪心选择的 性质。
12.常见的两种分支限界法为 队列式 和 优先队列式 。
13.解决0/1背包问题可以使用动态规划、回溯法和分支限界法,其中需要排序的是 回溯法 ,不需要排序的是 动态规划和分支限界法 。
14.f ( n ) = 6 × 2n + n 2,f(n)的渐进性态f ( n ) = O ( 2^n )。
15.对于含有n 个元素的排列树问题,最好情况下计算时间复杂性为 ,最坏情况下计算时间复杂性为 n! 。
16.在忽略常数因子的情况下,O 、Ω和Θ三个符号中, Θ 提供了算法运行时间的一个上界。
17.回溯法的求解过程,即在问题的解空间树中,按 深度优先 策略从根结点出发搜索解空间树。
《算法分析与设计》期末复习题[1]
![《算法分析与设计》期末复习题[1]](https://img.taocdn.com/s3/m/8701d1e35ef7ba0d4a733b9b.png)
一、选择题1.一个.java文件中可以有()个public类。
A.一个B.两个C.多个D.零个2.一个算法应该是()A.程序B.问题求解步骤的描述C.要满足五个基本特性D.A和C3.用计算机无法解决“打印所有素数”的问题,其原因是解决该问题的算法违背了算法特征中的()A.唯一性B.有穷性C.有0个或多个输入D.有输出4.某校有6位学生参加学生会主席竞选,得票数依次为130,20,98,15,67,3。
若采用冒泡排序算法对其进行排序,则完成第二遍时的结果是()A.3,15,130,20,98,67B.3,15,20,130,98,67C.3,15,20,67,130,98 D.3,15,20,67,98,1305.下列关于算法的描述,正确的是()A.一个算法的执行步骤可以是无限的B.一个完整的算法必须有输出C.算法只能用流程图表示D.一个完整的算法至少有一个输入6.Java Application源程序的主类是指包含有()方法的类。
A、main方法B、toString方法C、init方法D、actionPerfromed方法7.找出满足各位数字之和等于5的所有三位数可采用的算法思路是()A.分治法B.减治法C.蛮力法D.变治法8.在编写Java Application程序时,若需要使用到标准输入输出语句,必须在程序的开头写上( )语句。
A、import java.awt.* ;B、import java.applet.Applet ;C、import java.io.* ;D、import java.awt.Graphics ;9.计算某球队平均年龄的部分算法流程图如图所示,其中:c用来记录已输入球员的人数,sum用来计算有效数据之和,d用来存储从键盘输入的球员年龄值,输入0时表示输入结束。
图中空白处理框①和②处应填入的是()A.①sum ←sum + d B.①sum ←sum + c②c ←c + 1②c ←c + 1C.①sum ←sum + d D.①sum ←sum + c②d ←d + 1 ②d ←d + 110.报名参加冬季越野赛跑的某班5位学生的学号是:5,8,11,33,45。
算法设计与分析历年期末试题整理_含答案_

《算法设计与分析》历年期末试题整理(含答案)(1)用计算机求解问题的步骤:1、问题分析2、数学模型建立3、算法设计与选择4、算法指标5、算法分析6、算法实现 7、程序调试 8、结果整理文档编制(2)算法定义:算法是指在解决问题时,按照某种机械步骤一定可以得到问题结果的处理过程(3)算法的三要素1、操作2、控制结构3、数据结构算法具有以下5 个属性:有穷性:一个算法必须总是在执行有穷步之后结束,且每一步都在有穷时间内完成。
确定性:算法中每一条指令必须有确切的含义。
不存在二义性。
只有一个入口和一个出口可行性:一个算法是可行的就是算法描述的操作是可以通过已经实现的基本运算执行有限次来实现的。
输入:一个算法有零个或多个输入,这些输入取自于某个特定对象的集合。
输出:一个算法有一个或多个输出,这些输出同输入有着某些特定关系的量。
算法设计的质量指标:正确性:算法应满足具体问题的需求;可读性:算法应该好读,以有利于读者对程序的理解;健壮性:算法应具有容错处理,当输入为非法数据时,算法应对其作出反应,而不是产生莫名其妙的输出结果。
效率与存储量需求:效率指的是算法执行的时间;存储量需求指算法执行过程中所需要的最大存储空间。
一般这两者与问题的规模有关。
经常采用的算法主要有迭代法、分而治之法、贪婪法、动态规划法、回溯法、分支限界法迭代法也称“辗转法”,是一种不断用变量的旧值递推出新值的解决问题的方法。
利用迭代算法解决问题,需要做好以下三个方面的工作:一、确定迭代模型。
在可以用迭代算法解决的问题中,至少存在一个直接或间接地不断由旧值递推出新值的变量,这个变量就是迭代变量。
二、建立迭代关系式。
所谓迭代关系式,指如何从变量的前一个值推出其下一个值的公式(或关系)。
迭代关系式的建立是解决迭代问题的关键,通常可以使用递推或倒推的方法来完成。
三、对迭代过程进行控制。
在什么时候结束迭代过程?这是编写迭代程序必须考虑的问题。
不能让迭代过程无休止地重复执行下去。
计算机算法设计与分析复习题与答案1

《算法分析与设计》期末复习题(一)一、选择题1.应用Johnson 法则的流水作业调度采用的算法是(D )A. 贪心算法B. 分支限界法C.分治法D. 动态规划算法2.Hanoi 塔问题如下图所示。
现要求将塔座A 上的的所有圆盘移到塔座B 上,并仍按同样顺序叠置。
移动圆盘时遵守Hanoi 塔问题的移动规则。
由此设计出解Hanoi 塔问题的递归算法正确的为:(B )Hanoi 塔3. 动态规划算法的基本要素为(C)A. 最优子结构性质与贪心选择性质B.重叠子问题性质与贪心选择性质C.最优子结构性质与重叠子问题性质D. 预排序与递归调用4. 算法分析中,记号O表示(B),记号Ω表示(A),记号Θ表示(D)。
A.渐进下界B.渐进上界C.非紧上界D.紧渐进界E.非紧下界5. 以下关于渐进记号的性质是正确的有:(A)A.f(n)(g(n)),g(n)(h(n))f(n)(h(n))=Θ=Θ⇒=ΘB. f(n)O(g(n)),g(n)O(h(n))h(n)O(f(n))==⇒=C. O(f(n))+O(g(n)) = O(min{f(n),g(n)})D. f(n)O(g(n))g(n)O(f(n))=⇔=6.能采用贪心算法求最优解的问题,一般具有的重要性质为:(A)A. 最优子结构性质与贪心选择性质B.重叠子问题性质与贪心选择性质C.最优子结构性质与重叠子问题性质D. 预排序与递归调用7. 回溯法在问题的解空间树中,按(D)策略,从根结点出发搜索解空间树。
A.广度优先B. 活结点优先 C.扩展结点优先 D. 深度优先8. 分支限界法在问题的解空间树中,按(A)策略,从根结点出发搜索解空间树。
A.广度优先B. 活结点优先 C.扩展结点优先 D. 深度优先9. 程序块(A)是回溯法中遍历排列树的算法框架程序。
A.B.C.D.10. 回溯法的效率不依赖于以下哪一个因素?(C )A.产生x[k]的时间;B.满足显约束的x[k]值的个数;C.问题的解空间的形式;D.计算上界函数bound的时间;E.满足约束函数和上界函数约束的所有x[k]的个数。
计算机算法设计与分析期末复习资料

计算机算法设计与分析期末复习资料一填空题(20x1=20分)1.当有多个算法来解决集合问题时,选择算法的主要原则是选择复杂度最低的算法。
2.函数本身定义的函数是递归函数。
该算法适用于求解动态规划问题。
4.贪心算法的两个基本要素是最优子结构性质、贪心选择性质。
5.在搜索解空间树时,回溯方法通常使用深度优先的方法来提高搜索效率,以避免无效搜索。
6.根据不同的求解目标,分枝定界法和回溯法分别通过广度优先遍历或最小代价优先和深度优先搜索解空间树。
7.分支界限法和回溯法主要区别在于求解目标和搜索方式不同。
8.在执行分支定界法时,通常使用该方法来实现最大优先级队列。
9.依据求解所花费的时间和所得到的结果不同,随机化算法大致分为数值随机化算法、蒙特卡罗算法、拉斯维加斯算法和舍伍德算法四类。
10.产生伪随机数最常用的方法是线性同余法。
11.线性规划算法中旋转轴变化的目的是调整基准内变量和基准外变量的位置。
12.在最大网络流问题中,增广路径是剩余网络中容量大于0的路径。
13.应用于动态规划的待解决问题的两个基本要素是:。
14.算法必须满足的四个特征是输入、输出、确定性和有限性。
15.算法复杂性依赖于、、三个方面的复杂因素。
16.实现递归调用的关键是17.动态规划算法解决问题的重要线索是问题的性质。
18.最优子结构性质是贪婪算法的关键特征。
19.分支界限法的求解目标是找出满足约束条件的一个解,或是在满足约束条件的解中找出在某种意义下的最优解。
20.有两种常见的解空间树:子集树和置换树。
21.分支界限算法依据其从和节点表中选择获得下一扩展节点的不同方式被分为22.对于任何约束标准线性规划问题,只要基本变量设置为0,就可以得到一个解。
三概念题(6x2=12分)1.算法复杂度:指算法运行所需的计算机资源量。
需要时间资源的量称为时间复杂度,需要空间资源源的量称为空间复杂性。
2.递归算法:直接或间接调用自身的算法称为递归算法。
《算法设计与分析》复习题参考答案

《算法设计与分析》复习题参考答案一、概念题:请解释下列术语。
1.数据元素的集合。
2.队列是一个线性表,限制为只能在固定的一端进行插入,在固定的另一端进行删除。
3.对于算法a,如果存在一多项式p(),使得对a的每个大小为n的输入,a的计算时间为o(p(n)),则称a具有多项式复杂度4.二叉树的层数i与该层上的结点数n的关系为:n(i)=i2。
5.如果可满足性约化为一个问题L,则称该问题为NP-难度的。
6.算法就是一组有穷的规则,它规定了解决某一特定类型问题的一系列运算。
7.多数据单指令流8.若图的任意两个节点间均存在路径可达,则称该图为连通图。
9. 是指一个数学模型以及定义在该模型上的一组操作。
10.算法的复杂度只能用指数函数对其限界。
11.函数或过程直接或间接调用它自己。
12.和高度相同的满二叉树的每个对应的顶点编号相同的树13.由所有可行状态所构成的树。
14.如果L时NP难度的且L∈NP,则称问题L是NP-完全的。
15.算法是一个步骤的序列,满足:有穷性、可行性、确定性、输入、输出;过程不需要满足由穷性。
16.有向图的每条边有起点与终点之分,且用箭头指向边的终点。
无向图的边无起点和终点之分,边无箭头。
17.树(tree)是一个或多个结点的有限集合,,它使得:①有一个特别指定的称作根(root)的结点;②剩下的结点被分成m≥0个不相交的集合tl,…,tm,这些集合的每一个都是一棵树,并称t1,…,tm为这根的子树(subtree)。
18.P是所有可在多项式时间内用确定算法求解的判定问题的集合。
19.运算结果是唯一确定的算法20. nP是所有可在多项式时间内用不确定算法求解的判定问题的集合二、填空题1.n2.O ( n )3.最优化问题4.宽度优先搜索5.结点的最大级数6.互异7.内结点和外结点8.方形9.内部路径长度、外部路径长度10.一次11.归并分类算法12.贪心选择性质13.最优子结构14.二元归并15.最小成本生成树16.最优性17.最优决策18.可容许最大成本c19.最小成本三、程序填空题。
算法设计与分析期末复习题

算法设计与分析期末考试复习题1.算法有哪些特点?为什么说一个具备了所有特征的算法,不一定就是使用的算法?2.证明下面的关系成立:(参考例题1.5--1.6)(1)logn!=Θ(nlogn) (2)2n=Θ(2n+1)(3)n!=Θ(n n) (4)5n2-6n=Θ(n2)3.考虑下面的算法:输入:n个元素的数组A输出:按递增顺序排序的数组A1. void sort(int A[],int n)2. {3. int i,j,temp;4. for(i=0;i<n-1;i++)5. for(j=i+1;j<n;j++)6. if(A[j]<A[i]) {7. temp=A[i];8. A[i]=A[j];9. A[j]=temp;10. }11. }(1)什么时候算法所执行的元素赋值的次数最少?最少多少次?(2)什么时候算法所执行的元素赋值的次数最多?最多多少次?4.考虑下面的算法:输入:n个元素的数组A输出:按递增顺序排序的数组A1. void bubblesort(int A[],int n)2. {3. int j,i,sorted;4. i=sorted=0;5. while(i<n-1 && !sorted) {6. sorted=1;7. for(j=n-1;j>i;j--) {8. if(A[j]<A[j-1]) {9. temp=A[j];10. A[j]=A[j-1];11. A[j-1]=temp;12. sorted=0;13. }14. }15. i=i+1;16. }17. }(1)算法所执行的元素比较次数最少是多少次?什么时候达到最少?(2)算法所执行的元素比较次数最多是多少次?什么时候达到最多?(3)算法所执行的元素赋值次数最少是多少次?什么时候达到最少?(4)算法所执行的元素赋值次数最多是多少次?什么时候达到最多?(5)用О、和Ω记号表示算法的运行时间。
计算机算法与设计复习题(含答案) (1)

一、选择题1、衡量一个算法好坏的标准是(C )。
(A)运行速度快(B)占用空间少(C)时间复杂度低(D)代码短2、记号O的定义正确的是(A)。
(A)O(g(n)) = { f(n) | 存在正常数c和n0使得对所有n≥n0有:0≤f(n) ≤cg(n) };(B)O(g(n)) = { f(n) | 存在正常数c和n0使得对所有n≥n0有:0≤cg(n) ≤f(n) };(C)O(g(n)) = { f(n) | 对于任何正常数c>0,存在正数和n0 >0使得对所有n≥n0 有:0 ≤f(n)<cg(n) };(D)O(g(n)) = { f(n) | 对于任何正常数c>0,存在正数和n0 >0使得对所有n≥n0 有:0 ≤cg(n) < f(n) };3、二分搜索算法是利用( A )实现的算法。
(A)分治策略(B)动态规划法(C)贪心法(D)回溯法4、使用分治法求解不需要满足的条件是(A )。
(A)子问题必须是一样的(B)子问题不能够重复(C)子问题的解可以合并(D)原问题和子问题使用相同的方法解5、合并排序算法是利用(A)实现的算法。
(A)分治策略(B)动态规划法(C)贪心法(D)回溯法6、实现大整数的乘法是利用(C )的算法。
(A)贪心法(B)动态规划法(C)分治策略(D)回溯法7、以下不可以使用分治法求解的是(D )。
(A)棋盘覆盖问题(B)选择问题(C)归并排序(D)0/1背包问题8、实现循环赛日程表利用的算法是( A )。
(A)分治策略(B)动态规划法(C)贪心法(D)回溯法9、实现棋盘覆盖算法利用的算法是( A )。
(A)分治法(B)动态规划法(C)贪心法(D)回溯法10、矩阵连乘问题的算法可由(B)设计实现。
(A)分支界限算法(B)动态规划算法(C)贪心算法(D)回溯算法11、实现大整数的乘法是利用的算法( C )。
(A)贪心法(B)动态规划法(C)分治策略(D)回溯法12、最长公共子序列算法利用的算法是(B)(A)分支界限法(B)动态规划法(C )贪心法(D)回溯法13、下列算法中通常以自底向上的方式求解最优解的是(B )(A)备忘录法(B)动态规划法(C)贪心法(D)回溯法14、下列是动态规划算法基本要素的是(D)(A)定义最优解(B)构造最优解(C)算出最优解(D)子问题重叠性质15、下列不是动态规划算法基本步骤的是( A )。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
一、基本题:算法:1、程序是算法用某种程序设计语言的具体实现。
2、算法就是一组有穷的序列(规则) ,它们规定了解决某一特定类型问题的一系列运算。
3、算法的复杂性是算法效率的度量,是评价算法优劣的重要依据。
4、算法的“确定性”指的是组成算法的每条指令是清晰的,无歧义的。
5、算法满足的性质:输入、输出、确定性、有限性。
6、衡量一个算法好坏的标准是时间复杂度低。
7、算法运行所需要的计算机资源的量,称为算法复杂性,主要包括时间复杂性和空间复杂性。
8、任何可用计算机求解的问题所需的时间都与其规模有关。
递归与分治:9、递归与分治算法应满足条件:最优子结构性质与子问题独立。
10、分治法的基本思想是首先将待求解问题分解成若干子问题。
11、边界条件与递归方程是递归函数的两个要素。
12、从分治法的一般设计模式可以看出,用它设计出的程序一般是递归算法。
13、将一个难以直接解决的大问题,分解成一些规模较小的相同问题,以便各个击破。
这属于分治法的解决方法。
14、Strassen矩阵乘法是利用分治策略实现的算法。
15、大整数乘积算法是用分治法来设计的。
16、二分搜索算法是利用分治策略实现的算法。
动态规划:17、动态规划算法的两个基本要素是最优子结构性质和重叠子问题性质。
18、下列算法中通常以自底向上的方式求解最优解的是动态规划法。
19、备忘录方法是动态规划算法的变形。
20、最优子结构性质是贪心算法与动态规划算法的共同点。
21、解决0/1背包问题可以使用动态规划、回溯法,其中不需要排序的是动态规划,需要排序的是回溯法。
贪心算法:22、贪心算法总是做出在当前看来最好的选择。
也就是说贪心算法并不从整体最优考虑,它所做出的选择只是在某种意义上的局部最优解。
23、最优子结构性质是贪心算法与动态规划算法的共同点。
24、背包问题的贪心算法所需的计算时间为 O(nlogn) 。
回溯法:25、回溯法中的解空间树结构通常有两种,分别是子集树和排列树。
(3)26、回溯法搜索解空间树时,常用的两种剪枝函数为约束函数和限界函数。
27、解决0/1背包问题可以使用动态规划、回溯法,其中不需要排序的是动态规划,需要排序的是回溯法。
28、使用回溯法进行状态空间树裁剪分支时一般有两个标准:约束条件和目标函数的界,N皇后问题和0/1背包问题正好是两种不同的类型,其中同时使用约束条件和目标函数的界进行裁剪的是 0/1背包,只使用约束条件进行裁剪的是 N 皇后问题。
29 用搜索算法解旅行售货员问题时的解空间树是排列树。
30 回溯法搜索状态空间树是按照深度优先遍历的顺序。
31、回溯法算法是以深度优先策略进行搜索的。
32、0-1背包问题的回溯算法所需的计算时间为 O(n2n)分支限界法:33、以广度优先搜索或以最小耗费(最大效益)优先的方式搜索问题解的算法称为分支限界法。
34、分支限界法主要有队列式(FIFO)分支限界法和优先队列式分支限界法。
35、分支限界法解旅行售货员问题时,活结点表的组织形式是最小堆。
其他:36、10000*n^2+10*n+1的时间复杂度是______。
37、f(n)=n^2+10*n+1000000的时间复杂度是______。
38、算法分析中,记号O表示渐进上界。
39、f(n)= 6×2n+n2,f(n)的渐进上界是 O(2^n)。
40、f(n)= 6×2n+n2,f(n)的渐进上界是 O(n^2)。
41、f(n)= 100×3n+10000×n2,f(n)的渐进上界是_____________。
42、f(n)= 6×4n+n2,f(n)的渐进上界是 O(2^n) 。
43、按照渐近阶从低到高的顺序排列下列表达式:4n2,logn,3n, n2/3,n!,2n。
Logn< n2/3<4n2<2n<3n<n! 。
1、下列不是动态规划算法基本步骤的是(A)。
A、找出最优解的空间结构B、构造最优解C、算出最优解D、定义最优解2、下面哪种函数是回溯法中为避免无效搜索采取的策略( B ).A、递归函数B、剪枝函数C、随机数函数D、搜索函数3、以下描述正确的是(B)A、递归算法只能直接调用自身B、递归函数是由函数自身给出定义的C、每个递归函数不一定都要有非递归定义的初始值D、以上都不正确4、以下描述不正确的是( C )A、组成算法的每条指令是没有歧义的B、算法中每条指令的执行时间是有限的C、在算法的循环结构中,指令的执行次数可以无限D、组成算法的每条指令是清晰的5、二分搜索算法是利用( A )实现的算法。
A、分治策略B、动态规划法C、贪心法D、回溯法6、下面关于算法的错误说法是( B )A、算法必须有输出B、算法必须在计算机上用某种语言实现C、算法不一定有输入D、算法必须在有限步执行后能结束7、0-1背包问题的回溯算法所需的计算时间为(A)A、O(n2n)B、O(nlogn)C、O(2n)D、O(n)8、有3个矩阵A维数是{10*100},B维数是{100*5},C维数是{5*50},若按((AB)C)计算,3个矩阵连乘积需要的乘法次数是( A )A、7500B、75000C、750D、7500009、用计算机解决问题的步骤一般为:( D)①编写程序②设计算法③分析问题④调试程序A.①②③④ B. ③④①② C. ②③①④ D. ③②①④10、以下哪种算法是以广度优先策略进行搜索的(B)A、回溯法B、分支界限法C、贪心算法D、随机化算法11、设序列X={x1,x2,…,xm}和Y={y1,y2,…,yn}的最长公共子序列为Z={z1,z2,…,zk} ,则以下描述不正确的是( D)A、若xm=yn,则zk=xm=yn,且Zk-1是Xm-1和Yn-1的最长公共子序列B、若xm≠yn且zk≠xm,则Z是xm-1和Y的最长公共子序列C、若xm≠yn且zk≠yn,则Z是X和yn-1的最长公共子序列D、若xm=yn,则zk≠xm≠yn,且Zk-1是Xm-1和Yn-1的最长公共子序列12、下列算法中通常以深度优先方式系统搜索问题解的是( D )。
A、备忘录B、动态规划法C、贪心法D、回溯法13、Strassen矩阵乘法是利用(A)实现的算法。
A、分治策略B、动态规划法C、贪心法D、回溯法14、以下对于动态规划描述不正确的是( D)A、动态规划法与分治法类似,其基本思想也是将待求解问题分解成若干子问题B、适合于用动态规划求解的问题,经分解得到的子问题往往不是互相独立的C、具体的动态规划算法多种多样,但是他们具有相同的填表格式D、动态规划求解问题时和分治法一样,对子问题重复计算多次15、矩阵A是一个p*q矩阵,B是q*r矩阵,则其乘积C=AB是一个( B)矩阵A、p*qB、p*rC、q*rD、p*q16、将一个难以直接解决的大问题,分解成一些规模较小的相同问题,以便各个击破。
这属于( B )的解决方法。
A、动态规划B、分治法C、贪心算法D、分支界限法17、动态规划算法适用于解最优化问题,以下哪个不是动态规划法解决问题的步骤(C)A、找出最优解的性质,并刻画其结构特征B、递归地定义最优值C、以自顶向下的方式计算出最优值D、根据计算最优值时得到的信息,构造最优解18、在对问题的解空间树进行搜索的方法中,一个活结点有多次机会成为活结点的是( A)。
A、回溯法B、分支限界法C、回溯法和分支限界法D、回溯法求解子集树问题19、以下哪种算法是以深度优先策略进行搜索的( A)A、回溯法B、分支界限法C、贪心算法D、随机化算法20、(D)是贪心算法与动态规划算法的共同点。
A 、重叠子问题 B、构造最优解C、贪心选择性质D、最优子结构性质21、下列算法中通常以自底向上的方式求解最优解的是( B )。
A、分治法B、动态规划法C、贪心法D、回溯法22、分支限界法解旅行售货员问题时,活结点表的组织形式是( A )。
A、优先队列B、链表C、栈D、数组23、回溯法搜索状态空间树是按照(C)的顺序。
A、中序遍历B、广度优先遍历C、深度优先遍历D、层次优先遍历23、衡量一个算法好坏的标准是( C )。
A、运行速度快B、占用空间少C、时间复杂度低D、代码短24、用搜索算法解旅行售货员问题时的解空间树是(B)。
A、子集树B、排列树C、深度优先生成树D、广度优先生成树25、以下增长最快的是( D)A、log2n B、nlog2n C、n2 D、2n26、背包问题的贪心算法所需的计算时间为( B)。
A、O(n2n)B、O(nlogn)C、O(2n)D、O(n)27、备忘录方法是那种算法的变形。
( B )A、分治法B、动态规划法C、贪心法D、回溯法15、一只青蛙一次可以跳上1级台阶,也可以跳上2级。
求该青蛙跳上一个n级的台阶总共有多少种跳法,并输出每种跳法具体怎么跳。
#include <iostream>using namespace std;void BackTrack_TAIJIE(int*x,int n,int i,int sum){ if(sum == n){cout<<n<<"="<<x[0];for(int k = 1; k < i; k++)cout<<"+"<<x[k];cout<<endl;return ;}if(sum > n)return ;x[i] = 1;BackTrack_TAIJIE(x,n,i+1,sum+1);x[i] = 2;BackTrack_TAIJIE(x,n,i+1,sum+2);}void ProcTaiJie(int n){int* x = new int[n];BackTrack_TAIJIE(x,n,0,0);delete [] x;}int main(){ cout<<" 跳法"<<endl;ProcTaiJie(8);return 0;}19. 高矮不同的12个人,排成两排,每排必须是从矮到高排列,而且第二排比对应的第一排的人高,问排列方式有多少种? 输出132种#include<stdlib.h>#include<stdio.h>int arr[2][6];//2行6列数组,代表两个队列int resolution = 0;//答案个数int k0 = 0, k1 = 0;//各行已填充个数/*arr:数组*/void process(int curnum){if(curnum == 12){if(arr[1][5] == 0){resolution++;}return ;}//如果0行填充个数与1行填充个数相等,则当前数填充0行if(k0 == k1){arr[0][k0] = curnum;k0++;process(curnum+1);arr[0][k0] = 0;k0--;return;}//第0行最多填充到6个if(k0 < 6){arr[0][k0] = curnum;k0++;process(curnum+1);arr[0][k0] = 0;k0--;}arr[1][k1] = curnum;k1++;process(curnum+1);arr[1][k1] = 0;k1--;}int main(){int* pr = &resolution;//初始化数组int i,j;for(i = 0; i < 2; i++){for(j = 0; j < 6; j++){arr[i][j] = 0;}}arr[0][0] = 1;k0=1;process(2);arr[0][0] = 0;printf("%d",resolution);return 0;}24、把一个数组进行逆序存储,如1,2,3逆序存储为3,2,1 ,空间复杂度为O(1). (不太对)#include <stdio.h>int main(){ int i, n, swap, array[10];scanf("%d", &n);for (i = 0; i < n; i++)scanf("%d", &array[i]);for (i = 0; i < n/2; i++){swap = array[i];array[i] = array[n-1-i];array[n-1-i] = swap;}for (i = 0; i < n-1; i++)printf("%d ", array[i]);printf("%d\n", array[n-1]);return 0;}4、最大子段和问题:给出一个数列,数列元素均为负整数、0、正整数。