欢迎来到天天文库
浏览记录
ID:39631510
大小:573.07 KB
页数:19页
时间:2019-07-07
《2016算法设计与分析期末试题汇总》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库。
1、A卷一、选择题1.二分搜索算法是利用(A)实现的算法。A、分治策略 B、动态规划法 C、贪心法D、回溯法2.回溯法解旅行售货员问题时的解空间树是( A)。A、子集树B、排列树C、深度优先生成树D、广度优先生成树3.下列算法中通常以自底向上的方式求解最优解的是(B )。A、备忘录法B、动态规划法C、贪心法D、回溯法4.下面不是分支界限法搜索方式的是( D )。A、广度优先B、最小耗费优先C、最大效益优先D、深度优先5.采用贪心算法的最优装载问题的主要计算量在于将集装箱依其重量从小到大排序,故算法的时间复杂度为(B)。A、O(n2n)B、O(nlogn)C、
2、O(2n)D、O(n)6.分支限界法解最大团问题时,活结点表的组织形式是( B)。A、最小堆B、最大堆C、栈D、数组7、下面问题(B)不能使用贪心法解决。A单源最短路径问题BN皇后问题C最小花费生成树问题D背包问题8.下列算法中不能解决0/1背包问题的是(A)A贪心法B动态规划C回溯法D分支限界法9.背包问题的贪心算法所需的计算时间为( B )A、O(n2n) B、O(nlogn)C、O(2n) D、O(n)10.背包问题的贪心算法所需的计算时间为(B )。A、O(n2n)B、O(nlogn)C、O(2n)D、O(n)二、填空题1.算法的复杂性有复杂性和
3、复杂性之分。2.算法是由若干条指令组成的有穷序列,且要满足输入、、确定性和四条性质。其中算法的“确定性”指的是组成算法的每条是清晰的,无歧义的。3.解决0/1背包问题可以使用动态规划、回溯法和分支限界法,其中不需要排序的是,需要排序的是,。4.动态规划算法的两个基本要素是.性质和性质。5.回溯法是一种既带有又带有的搜索算法;分支限界法是一种既带有又带有的搜索算法。6.用回溯法解题的一个显著特征是在搜索过程中动态产生问题的解空间。在任何时刻,算法只保存从根结点到当前扩展结点的路径。如果解空间树中从根结点到叶结点的最长路径的长度为h(n),则回溯法所需的计算空间通
4、常为。7.用回溯法解图的m着色问题时,使用下面的函数OK检查当前扩展结点的每一个儿子所相应的颜色的可用性,则需耗时(渐进时间上限)。BoolColor::OK(intk){//for(intj=1;j<=n;j++)if((a[k][j]==1)&&(x[j]==x[k]))returnfalse;returntrue;}8.用回溯法解布线问题时,求最优解的主要程序段如下。如果布线区域划分为的方格阵列,扩展每个结点需O(1)的时间,L为最短布线路径的长度,则算法共耗时,构造相应的最短距离需要时间。for(inti=0;i5、row=here.row+offset[i].row;nbr.col=here.col+offset[i].col;if(grid[nbr.row][nbr.col]==0){//该方格未标记grid[nbr.row][nbr.col]=grid[here.row][here.col]+1;if((nbr.row==finish.row)&&(nbr.col==finish.col))break;//完成布线Q.Add(nbr);}}9.快速排序算法是基于的一种排序算法。10.是贪心算法可行的第一个基本要素,也是贪心算法与动态规划算法的主要区别三.简答题1.设6、计动态规划算法的主要步骤是怎么的?请简述。2.分治法所能解决的问题一般具有哪几个特征?请简述。3.分支限界法的搜索策略是什么?四.计算题1.已知非齐次递归方程:,其中,b、c是常数,g(n)是n的某一个函数。则f(n)的非递归表达式为:。现有Hanoi塔问题的递归方程为:,求h(n)的非递归表达式。2.给定带权有向图(如下图所示)G=(V,E),其中每条边的权是非负实数。另外,还给定V中的一个顶点,称为源。现在要计算从源到所有其它各顶点的最短路长度。这里路的长度是指路上各边权之和。现采用Dijkstra算法计算从源顶点1到其它顶点间最短路径。请将此过程填入下表7、中。4321{1}初始dist[5]dist[4]dist[3]dist[2]uS迭代三.程序题1.试用贪心算法求解汽车加油问题:已知一辆汽车加满油后可行驶n公里,而旅途中有若干个加油站。试设计一个有效算法,指出应在哪些加油站停靠加油,使加油次数最少,请写出该算法。2.试用动态规划算法实现下列问题:设A和B是两个字符串。我们要用最少的字符操作,将字符串A转换为字符串B,这里所说的字符操作包括:(1)删除一个字符。(2)插入一个字符。(3)将一个字符改为另一个字符。请写出该算法。答案:一、AABDBBBABB二、1.时间空间1.输出有限性指令2.动态规划回溯法分8、支限界法3.最优子结构重叠子问题4.系
5、row=here.row+offset[i].row;nbr.col=here.col+offset[i].col;if(grid[nbr.row][nbr.col]==0){//该方格未标记grid[nbr.row][nbr.col]=grid[here.row][here.col]+1;if((nbr.row==finish.row)&&(nbr.col==finish.col))break;//完成布线Q.Add(nbr);}}9.快速排序算法是基于的一种排序算法。10.是贪心算法可行的第一个基本要素,也是贪心算法与动态规划算法的主要区别三.简答题1.设
6、计动态规划算法的主要步骤是怎么的?请简述。2.分治法所能解决的问题一般具有哪几个特征?请简述。3.分支限界法的搜索策略是什么?四.计算题1.已知非齐次递归方程:,其中,b、c是常数,g(n)是n的某一个函数。则f(n)的非递归表达式为:。现有Hanoi塔问题的递归方程为:,求h(n)的非递归表达式。2.给定带权有向图(如下图所示)G=(V,E),其中每条边的权是非负实数。另外,还给定V中的一个顶点,称为源。现在要计算从源到所有其它各顶点的最短路长度。这里路的长度是指路上各边权之和。现采用Dijkstra算法计算从源顶点1到其它顶点间最短路径。请将此过程填入下表
7、中。4321{1}初始dist[5]dist[4]dist[3]dist[2]uS迭代三.程序题1.试用贪心算法求解汽车加油问题:已知一辆汽车加满油后可行驶n公里,而旅途中有若干个加油站。试设计一个有效算法,指出应在哪些加油站停靠加油,使加油次数最少,请写出该算法。2.试用动态规划算法实现下列问题:设A和B是两个字符串。我们要用最少的字符操作,将字符串A转换为字符串B,这里所说的字符操作包括:(1)删除一个字符。(2)插入一个字符。(3)将一个字符改为另一个字符。请写出该算法。答案:一、AABDBBBABB二、1.时间空间1.输出有限性指令2.动态规划回溯法分
8、支限界法3.最优子结构重叠子问题4.系
此文档下载收益归作者所有