计算机算法设计和分析》习题及答案解析_第1页
计算机算法设计和分析》习题及答案解析_第2页
计算机算法设计和分析》习题及答案解析_第3页
计算机算法设计和分析》习题及答案解析_第4页
计算机算法设计和分析》习题及答案解析_第5页
已阅读5页,还剩3页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

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

2、) 。A 运行速度快B 占用空间少C 时间复杂度低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哈夫曼编码的贪心算法

3、所需的计算时间为(B ) 。A、O( n2n) B、 O( nlogn ) C 、 O(2n) D、 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. 计算约束函数

4、的时间C. 计算限界函数的时间D. 确定解空间的时间18. 下面哪种函数是回溯法中为避免无效搜索采取的策略(B )A.递归函数B.剪枝函数C 。随机数函数D.搜索函数19. (D)是贪心算法与动态规划算法的共同点。A、重叠子问题B、构造最优解 C、贪心选择性质D、最优子结构性质20. 矩阵连乘问题的算法可由(B )设计实现。A、分支界限算法B 、动态规划算法C、贪心算法D、回溯算法21. 分支限界法解旅行售货员问题时,活结点表的组织形式是(A ) 。A最小堆 B、最大堆 C 、栈 D 、数组22、 Strassen 矩阵乘法是利用(A )实现的算法。A、分治策略B 、动态规划法C、贪心法 D、

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

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

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

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

9、 )。A、分治策略 B、动态规划法 C、贪心法 D、回溯法45. Hanoi塔问题如下图所示。现要求将塔座 A上的的所有圆盘移到塔座 B上,并仍按 同样顺序叠置。移动圆盘时遵守 Hanoi塔问题的移动规则。由此设计出解Hanoi塔问题的递 归算法正确的为:(B)A. void hanoi(int n, int A, int C, int B)B.vfidr,ha°oi(int n, int A, int B, int C)Cvoi由an0)( (祢A,Cn 电 int B, int A)Hanoi 塔4D,及 (n吊i翅吟童心送择性质)int A, ini B)一问题性质就断0蠢谎南

10、祸问题,-47.”采A.九hwoHn-1岫撮心A)择性质B .重叠子问D.预排序与般具有的重要性质为题性质与贪心选择性质 递归调用(A )C.捻优子结构性质与重叠子问题性质 48.回溯法在问题的解空间树中,按(B .重叠子问题性质与贪心选择性质D.预排序与递归调用D )策略,从根结点出发搜索解空间树。50.A.B.C.D.51.A.B.C.D.voidVoid vod e e,backtrack, (int t) 镰ipk溯t)Se广度f 队列X 排列树队效二、填空题常见勺两D附册法;奥法与堆R式4支限界法;es我臃蝴鬻皆族-1);swap (布片蝴;去与优先队列式分支限界法if (legal

11、(t) backtrack(t+1);1.算法的复杂性有时间复杂性和空间复杂性之分。A.广度优先 B.活结点优先C.扩展结点优先 D. 深度优先49.分支限界法在问题的解空间树中,按 (A )策略,从根结点出发搜索解空间树。A.广度优先 B. 活结点优先 C.扩展结点优先D. 深度优先 程序块(A )是回溯法中遍历排列树的算法框架程序。2、程序是算法用某种程序设计语言的具体实现。3、算法的“确定性”指的是组成算法的每条指令是清晰的,无歧义的。4.矩阵连乘问题的算法可由动态规划设计实现。5、算法是指解决问题的一种方法 或一个过程递归算法6、从分治法的一般设计模式可以看出,用它设计出的程序一般是7

12、、问题的最优子结构性质是该问题可用动态规划算法或贪心算法求解的关键特征。8、以深度优先方式系统搜索问题解的算法称为回溯法 。9、计算一个算法时间复杂度通常可以计算循环次数、基本操作的频率或计算步。10、解决0/1背包问题可以使用动态规划、回溯法和分支限界法, 其中不需要排序的是动态规划 ,需要排序的是回溯法 ,分支限界法。11、使用回溯法进行状态空间树裁剪分支时一般有两个标准:约束条件和目标函数的界,N皇后问题和0/1背包问题正好是两种不同的类型,其中同时使用约束条件和目标函数的界进行裁剪的是 0/1背包问题,只使用约束条件进行裁剪的是N 皇后问题。12、 贪心选择性质是贪心算法可行的第一个基

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

14、排序算法。21 .动态规划算法的两个基本要素是.最优子结构性质和 重叠子问题 性质。22 .回溯法是一种既带有系统性 又带有 跳跃性 的搜索算法。23 .分支限界法主要有队列式(FIFO)分支限界法和优先队列式分支限界法。24 .分支限界法是一种既带有系统性 又带有 跳跃性的搜索算法。25 .回溯法搜索解空间树时,常用的两种剪枝函数为约束函数 和 限界函数。26 .任何可用计算机求解的问题所需的时间都与其规模 有关。27 .快速排序算法的性能取决于划分的对称性。28 .所谓贪心选择性质是指所求问题的整体最优解可以通过一系列局部最优的选择,即贪心选择来达到。29 .所谓最优子结构性质是指问题的最

15、优解包含了其子问题的最优解。30 .回溯法是指具有限界函数的深度优先生成法。31 .用回溯法解题的一个显着特征是在搜索过程中动态产生问题的解空间。在任何时刻,算法只保存从根结点到当前扩展结点的路径。如果解空间树中从根结点到叶结点的最长路径的长度为h(n),则回溯法所需的计算空间通常为O(h(n)。32 .回溯法的算法框架按照问题的解空间一般分为子集树算法框架与排列树算法框架。33 .用回溯法解0/1背包问题时,该问题的解空间结构为子集树 结构。34 .用回溯法解批处理作业调度问题时,该问题的解空间结构为排列树结构。35 .旅行售货员问题的解空间树是排列树 。三、算法填空1 .背包问题的贪心算法

16、void Knapsack(int n,float M,float v,float w,float x口)n,价值为v1.n的n个物品,装入容量为M的背包nint i; Sort(n,v,w);for (i=1;i<=n;i+) xi=0;float c=M;for (i=1;i<=n;i+)if (wi>c) break;xi=1;c-=w|jif (i<=n) xi=c/wi;2 .最大子段和:动态规划算法int MaxSum(int n, int a)int sum=0, b=0;心算法求活动安排问题template<class Type>void G

17、reedySelector (int n, Type s, Type f, bool A) A1=true;int j=1;for (int i=2;i<=n;i+) if (si>=fj) Ai=true;j=i;else Ai=false;4 .快速排序template<class Type>void Quicksort (Type a, int p, int r)if (p<r)int q=Partition(a,p,r);Quicksort (a,p,q-1); 回溯法解迷宫问题迷宫用二维数组存储,用'H'表示墙,'O'表示

18、通道int x1,y1,success=0;给定已按升序排好序的n个元素a0:n-1,现要在这n个元素中找出一特定元素 x,返回其在数组中的位置,如果未找到返回 -1。写出二分搜索的算法,并分析其时间复杂度。template<class Type>int BinarySearch(Type a口,const Type& x, int n)利用分治算法写出合并排序的算法,并分析其时间复杂度void MergeSort(Type a, int left, int right)if (left<right) 大团问题void Clique:Backtrack(int i)顺序表存储表示如下:typedef structRedType rMAXSIZE+1; high 的记录 , 枢轴记录

温馨提示

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

评论

0/150

提交评论