【算法设计与分析】期末复习题(超详细)

文章详细回顾了算法设计中的重要概念,如分治策略、动态规划、贪心算法,以及它们在填空题、设计题和简答题中的应用,涉及时间复杂性、空间复杂性、背包问题解决方案等。
摘要由CSDN通过智能技术生成

刚刚整理了一下电脑的文件,发现了这份上学期的算法设计与分析期末复习题,有需要的文后自取。

一、填空题

1.二分搜索算法是利用( A )实现的算法。
A、分治策略 B、动态规划法 C、贪心法 D、回溯法
2.最大效益优先是( A )的一搜索方式。
A、分支界限法 B、动态规划法 C、贪心法 D、回溯法
3.最长公共子序列算法利用的算法是( B )。
A、分支界限法 B、动态规划法 C、贪心法 D、回溯法
4.下列算法中通常以自底向上的方式求解最优解的是( B )。
A、备忘录法 B、动态规划法 C、贪心法 D、回溯法
5.衡量一个算法好坏的标准是(C )。
A 运行速度快 B 占用空间少 C 时间复杂度低 D 代码短
6.以下不可以使用分治法求解的是(D )。
A 棋盘覆盖问题 B 选择问题 C 归并排序 D 0/1背包问题(回溯、分支限界、动态规划)
7. 实现循环赛日程表利用的算法是( A )。
A、分治策略 B、动态规划法 C、贪心法 D、回溯法
8、实现最长公共子序列利用的算法是( B )。
A、分治策略 B、动态规划法 C、贪心法 D、回溯法
9.下面不是分支界限法搜索方式的是( D )。
A、广度优先 B、最小耗费优先 C、最大效益优先 D、深度优先
10.下列算法中通常以深度优先方式系统搜索问题解的是( D )。
A、备忘录法 B、动态规划法 C、贪心法 D、回溯法
11. 一个问题可用动态规划算法或贪心算法求解的关键特征是问题的( B )。
A、重叠子问题 B、最优子结构性质 C、贪心选择性质 D、定义最优解
12.广度优先是( A )的一搜索方式。
A、分支界限法 B、动态规划法 C、贪心法 D、回溯法
13.背包问题的贪心算法所需的计算时间为( B )。
A、O(n2n) B、O(nlogn) C、O(2n) D、O(n)
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 )
A.递归函数 B.剪枝函数 C。随机数函数 D.搜索函数
19、以深度优先方式系统搜索问题解的算法称为 ( D ) 。
A、分支界限算法 B、概率算法 C、贪心算法 D、回溯算法
20、贪心算法与动态规划算法的主要区别是( B )。(cd为动态规划的基本步骤)
A、最优子结构 B、贪心选择性质 C、构造最优解 D、定义最优解
21. 采用最大效益优先搜索方式的算法是( A )。
A、分支界限法 B、动态规划法 C、贪心法 D、回溯法
22. ( D )是贪心算法与动态规划算法的共同点。
A、重叠子问题 B、构造最优解 C、贪心选择性质 D、最优子结构性质
23. 矩阵连乘问题的算法可由( B)设计实现。
A、分支界限算法 B、动态规划算法 C、贪心算法 D、回溯算法
24. 0-1背包问题的回溯算法所需的计算时间为( A )
A、O(n2n) B、O(nlogn) C、O(2n) D、O(n)
25、背包问题的贪心算法所需的计算时间为( B )
A、O(n2n) B、O(nlogn) C、O(2n) D、O(n)
26、使用分治法求解不需要满足的条件是(A )。
A 子问题必须是一样的 B 子问题不能够重复C 子问题的解可以合并 D 原问题和子问题使用相同的方法解
27、下面问题(B )不能使用贪心法解决。
A 单源最短路径问题 B N皇后问题 C 最小花费生成树问题 D 背包问题
28、下列算法中不能解决0/1背包问题的是(A )
A 贪心法 B 动态规划 C 回溯法 D 分支限界法
29、回溯法搜索状态空间树是按照(C )的顺序。
A 中序遍历 B 广度优先遍历 C 深度优先遍历 D 层次优先遍历
30、采用广度优先策略搜索的算法是( A )。
A、分支界限法 B、动态规划法 C、贪心法 D、回溯法
31.实现合并排序利用的算法是( A )。
A、分治策略 B、动态规划法 C、贪心法 D、回溯法
32.下列是动态规划算法基本要素的是( D )。
A、定义最优解 B、构造最优解 C、算出最优解(基本步骤)D、子问题重叠性质

二、 填空题

1、算法的复杂性有 时间 复杂性和 空间 复杂性之分。
6、快速排序算法的性能取决于 划分的对称性
7、从分治法的一般设计模式可以看出,用它设计出的程序一般是 递归算法
8、问题的 最优子结构性质 是该问题可用动态规划算法或贪心算法求解的关键特征。
9、以深度优先方式系统搜索问题解的算法称为 回溯法
12、回溯法搜索解空间树时,常用的两种剪枝函数为 约束函数限界函数
14、解决0/1背包问题可以使用动态规划、回溯法和分支限界法,其中不需要排序的是 动态规划 ,需要排序的是 回溯法 ,分支限界法
17、回溯法是一种既带有 系统性 又带有 跳跃性 的搜索算法。
18. 动态规划算法的两个基本要素是最优子结构性质重叠子问题 性质
19.贪心算法的基本要素是 贪心选择 性质和 最优子结构 性质 。
21. 动态规划算法的基本思想是将待求解问题分解成若干子问题,先求解子问题,然后从这些子问题 的解得到原问题的解。
23、快速排序算法是基于 分治策略 的一种排序算法。
24、以广度优先或以最小耗费方式搜索问题解的算法称为 分支限界法

三、算法设计题

1.背包问题的贪心算法和分支限界算法
2.最长公共子序列和动态规划算法
3.贪心算法求活动安排问题
5.快速排序
6. 多机调度问题-贪心算法

四、简答题

1.分治法的基本思想
分治法,即分而治之,将原问题划分为多个规模较小的子问题,子问题相互独立且与原问题相同,递归的求解这些子问题,然后将子问题的解合并得到原问题的解。

2.分治法与动态规划法的异同
分治法和动态规划都是算法设计策略,二者的主要区别在于动态规划利用重叠子问题性质,通过保存子问题解避免重复计算,而分治法通常独立解决子问题。

3.分支限界法与回溯法的异同
分支限界法和回溯法都是解决组合优化问题的算法,它们的主要区别在于对搜索状态的处理。回溯法通过深度优先搜索遍历所有可能的解空间,而分支限界法则通过优先级队列等数据结构,有选择地扩展最有希望的节点,以更高效地搜索解空间。分支限界法在搜索过程中使用启发式信息,剪枝不可能达到最优解的分支,从而提高搜索效率,而回溯法则一般通过递归地穷举所有可能解来找到问题的解。

4.分治法所能解决的问题一般具有的几个特征是:
分治法适用于问题具有可分性、子问题相似性、需要合并子问题解和递归应用的特征

5.用分支限界法设计算法的步骤:
分支限界法的算法设计步骤包括问题建模,创建状态空间树,选择节点进行扩展,利用启发式方法剪枝以减少搜索空间,动态更新节点的界限,选择最有希望的节点进行扩展,循环执行扩展和剪枝直至找到最优解或完全探索搜索空间,并最终输出结果。

6.回溯法中常见的两类典型的解空间树是:
A.子集树
B.排列树

7.分支限界法的搜索策略是:广度优先或者最小代价(最大效益)优先

在这里插入图片描述
关注”杂家话谈"回复”算法设计"获取本文相关文档,创作不易,感谢未来首富们的支持与关注!

  • 45
    点赞
  • 76
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值