算法期末复习题final
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
算法分析与设计期末复习题目
一、选择题
1.下列算法中通常以自底向上的方式求解最优解的是( B )。
A、备忘录法
B、动态规划法
C、贪心法
D、回溯法
2、衡量一个算法好坏的标准是(C )。
A 运行速度快
B 占用空间少
C 时间复杂度低
D 代码短
3、以下不可以使用分治法求解的是(D )。
A 棋盘覆盖问题
B 选择问题
C 归并排序
D 0/1背包问题
4.下列是动态规划算法基本要素的是( D )。
A、定义最优解
B、构造最优解
C、算出最优解
D、子问题重叠性质
5.采用广度优先策略搜索的算法是( A )。
A、分支界限法
B、动态规划法
C、贪心法
D、回溯法
6、合并排序算法是利用( A )实现的算法。
A、分治策略
B、动态规划法
C、贪心法
D、回溯法
7、下列不属于影响程序执行时间的因素有哪些( C )
A.算法设计的策略 B.问题的规模
C.编译程序产生的机器代码质量 D.计算机执行指令的速度
8、使用分治法求解不需要满足的条件是(A )。
A 子问题必须是一样的
B 子问题不能够重复
C 子问题的解可以合并
D 原问题和子问题使用相同的方法解
9、下面问题(B )不能使用贪心法解决。
A 单源最短路径问题
B N皇后问题
C 最小花费生成树问题
D 背包问题
10. 一个问题可用动态规划算法或贪心算法求解的关键特征是问题的( B )。
A、重叠子问题
B、最优子结构性质
C、贪心选择性质
D、定义最优解
11. 以深度优先方式系统搜索问题解的算法称为( D ) 。
A、分支界限算法
B、概率算法
C、贪心算法
D、回溯算法
12. 实现最长公共子序列利用的算法是( B )。
A、分治策略
B、动态规划法
C、贪心法
D、回溯法
13.下列算法具有最优子结构的算法是(D)
A.概率算法 B.回溯法 C.分支限界法 D.动态规划法
14.算法分析是( C)
A.将算法用某种程序设计语言恰当地表示出来
B.在抽象数据集合上执行程序,以确定是否会产生错误的结果
C.对算法需要多少计算时间和存储空间作定量分析
D.证明算法对所有可能的合法输入都能算出正确的答案
15衡量一个算法好坏的标准是(C )
16 A.运行速度快 B. 占用空间少 C.时间复杂度低 D. 代码短
16.二分搜索算法是利用(A)实现的算法。
A.分治法
B.动态规划法
C.贪心法
D.回溯法
17.用贪心法设计算法的关键是( B )。
A.将问题分解为多个子问题来分别处理
B.选好最优量度标准
C.获取各阶段间的递推关系式
D.满足最优性原理
18.找最小生成树的算法Kruskal 的时间复杂度为( D )(其中n 为无向图
的结点数,m 为边数)
A .O(n 2)
B .O(mlogn)
C .O(nlogm)
D .O(mlogm)
19.回溯法搜索状态空间树是按照(C )的顺序。
A.中序遍历
B.广度优先遍历
C.深度优先遍历
D.层次优先遍历
20.采用广度优先策略搜索的算法是( A )。
A.分支界限法
B.动态规划法
C.贪心法
D.回溯法
21.函数32n +10nlogn 的渐进表达式是( B ).
( 2n ) B. O( 32n ) C. O( nlog n ) D. O( 10nlog n )
22.二分搜索算法的时间复杂性为( C )。
(2n ) (n ) (n log ) D. O(n n log )
23、快速排序算法的时间复杂性为( D )。
(2n ) (n ) (n log ) D. O(n n log )
24、算法是由若干条指令组成的有穷序列,而且满足以下性质( D )
A.输入:有0个或多个输入
B.输出:至少有一个输出
C. 确定性:指令清晰,无歧义
D.有限性:指令执行次数有限,而且执行
时间有限
A. (1)(2)(3)
B. (1)(2)(4)
C. (1)(3)(4)
D.(1) (2)(3)(4)
25、背包问题的贪心算法所需的计算时间为( B )
A. O (n2n )
B. O (nlogn ) (2n ) (n )
26.下列算法中不能解决0/1背包问题的是( A )
A 贪心法
B 动态规划
C 回溯法
D 分支限界法
27. 在寻找n 个元素中第k 小元素问题中,若使用快速排序算法思想,运
用分治算法对n 个元素进行划分,应如何选择划分基准下面 (D) 答案解释最
合理。
A .随机选择一个元素作为划分基准
B .取子序列的第一个元素作为划分基准
C .用中位数的中位数方法寻找划分基准
D .以上皆可行。但不同方法,算法复杂度上界可能不同
28. 分治法的设计思想是将一个难以直接解决的大问题分割成规模较小的
子问题,分别解决子问题,最后将子问题的解组合起来形成原问题的解。这要
求原问题和子问题 ( C ) 。
A .问题规模相同,问题性质相同
B .问题规模相同,问题性质不同
C .问题规模不同,问题性质相同
D .问题规模不同,问题性质不同
29、下面是贪心算法的基本要素的是( C )。
A 、重叠子问题
B 、构造最优解
C 、贪心选择性质
D 、定义最
优解
30. 函数n n 1032 的渐进表达式是( D )。 A. O(23n ) B. O(3) C. O(n 10) (2
n )
二、填空题
1、解决0/1背包问题可以使用动态规划、回溯法和分支限界法,其中不需
要排序的是 动态规划 ,需要排序的是 回溯法 ,分支限界法 。
2、使用回溯法进行状态空间树裁剪分支时一般有两个标准:约束条件和目
标函数的界,N 皇后问题和0/1背包问题正好是两种不同的类型,其中同时使用
约束条件和目标函数的界进行裁剪的是 0/1背包问题 ,只使用约束条件
进行裁剪的是 N 皇后问题 。
3.贪心算法基本要素有 最优度量标准 和 最优子结构 。