网络教育课程考试复习题及参考答案 算法分析与设计 一、名词解释: 1.算法 2.程序 3.
递归函数 4.子问题的重叠性质 5.队列式分支限界法 6.多机调度问题 7.最小生成树 二、简答题: 1.备忘录方法和动态规划算法相比有何异同?简述之。 2.简述回溯法解题的主要步骤。 3.简述动态规划算法求解的基本要素。 4.简述回溯法的基本思想。 5.简要分析在递归算法中消除递归调用,将递归算法转化为非递归算法的方法。 6.简要分析分支限界法与回溯法的异同。 7.简述算法复杂性的概念,算法复杂性度量主要指哪两个方面? 8.贪心算法求解的问题主要具有哪些性质?简述之。 9.分治法的基本思想是什么?合并排序的基本思想是什么?请分别简述之。 10.简述分析贪心算法与动态规划算法的异同。 三、算法编写及算法应用分析题: 1.已知有3个物品:(w1,w2,w3)=(12,10,6),(p1,p2,p3)=(15,13,10),背包的容积M=20,根据0-1背包动态规划的递推式求出最优解。 2.按要求完成以下关于排序和查找的问题。 ①对数组A={15,29,135,18,32,1,27,25,5},用快速排序方法将其排成递减序。 ②请描述递减数组进行二分搜索的基本思想,并给出非递归算法。 ③给出上述算法的递归算法。 ④使用上述算法对①所得到的结果搜索如下元素,并给出搜索过程:18,31,135。 已知,=1,2,3,4,5,6,=5,=10,=3,=12,=5,=50,=6,kijr*r1234567ii1 求矩阵链积A×A×A×A×A×A的最佳求积顺序(要求给出计算步骤)。1234564.根据分枝限界算法基本过程,求解0-1背包问题。 已知n=3,M=20,(w1,w2,w3)=(12,10,6),(p1,p2,p3)=(15,13,10)。 5.试用贪心算法求解汽车加油问题:已知一辆汽车加满油后可行驶n公里,而旅途中有若干个加油站。试设计一个有效算法,指出应在哪些加油站停靠加油,使加油次数最少,请写出该算法。 6.试用动态规划算法实现下列问题:设A和B是两个字符串。我们要用最少的字符操作,将字符串A转换为字符串B,这里所说的字符操作包括: ①删除一个字符。 ②插入一个字符。 ③将一个字符改为另一个字符。 请写出该算法。 7.对于下图使用Dijkstra算法求由顶点a到顶点h的最短路径。 be2g212ad323182cf2h
8.试写出用分治法对数组A[n]实现快速排序的算法。 9.有n个活动争用一个活动室。已知活动i占用的时间区域为[s,f ],活动i,j相容的条件是:sj≥f ii,问题的解表示为(x| x =1,2…,n,),x表示顺序为i的活动编号活动,求一个相容的活动子集,iiii且安排的活动数目最多。 xxx10.设、、是一个三角形的三条边,而且x+x+x=14。请问有多少种不同的三角形?给出解答过程。 12312311.
设数组A有n个元素,需要找出其中的最大最小值。 ①请给出一个解决方法,并分析其复杂性。 ②把n个元素等分为两组A1和A2,分别求这两组的最大值和最小值,然后分别将这两组的最大值和最小值相比较,求出全部元素的最大值和最小值。如果A1和A2中的元素多于两个,则再用上述方法各分为两个子集。直至子集中元素至多两个元素为止。这是什么方法的思想?请给出该方法的算法描述,并分析其复杂性。
12.有n个程序和长度为L的磁带,程序i的长度为a,
已知 ,求最优解(x,x ,...,x,…,ii2i
x),x =0,
1, x =1,表示程序i存入磁带,x =0,表示程序i不存入磁带,满足,且
niii
存放的程序数目最多。 13.
试用分治法实现有重复元素的排列问题:设是要进行排列的个元素,其中元素12nr,r,...,rR可能相同,试设计计算的所有不同排列的算法。 12n14.试用动态规划算法实现0-1闭包问题,请写出该算法。 15.试用贪心算法求解下列问题:将正整数n分解为若干个互不相同的自然数之和,使这些自然数的乘积最大,请写出该算法。 16.试写出用分治法对一个有序表实现二分搜索的算法。 17.试用动态规划算法实现最长公共子序列问题,请写出该算法。 18.假设有7个物品,它们的重量和价值如下表所示。若这些物品均不能被分割,且背包容量M=150,使用回溯方法求解此背包问题,请写出状态空间搜索树。 物品 A B C D E F G 重量 35 30 60 50 40 10 25 价值 10 40 30 50 35 40 30 19.求解子集
和问题:对于集合S={1,2 ,6,8},求子集,要求该子集的元素之和d=9。 ①画出子集和问题的解空间树; ②该树运用回溯算法,写出依回溯算法遍历节点的顺序; ③如果S中有n个元素,指定d,用伪代码描述求解子集和问题的回溯算法。 20.求解填字游戏问题:在3×3个方格的方阵中要填入数字1到N(N≥10)内的某9个数字,每个方格填一个整数,似的所有相邻两个方格内的两个整数之和为质数。试采用回溯法写出满足这个要求的一种数字填法的算法和满足这个要求的全部数字填法的算法。
21.试用动态规划算法实现最大子矩阵和问
题:求矩阵A的一个子矩阵,使其各元素之和为最大。
i
22.试用回溯法解决下列整数变换
问题:关于整数的变换和定义如下:。对
nmnmfg
于给定的
两个整数和,要求用最少的变换和变换次数将变为。 23.关于15谜问题。在一个4×4的方格的棋盘上,将数字1到15代表的15个棋子以任意的顺序置入各方格中,空出一格。要求通过有限次的移动,把一个给定的初始状态变成目标状态。移动的规则是:每次只能把空格周围的四格数字(棋子)中的任意一个移入空格,从而形成一个新的状态。为了有效
的移动,设计了估值函数C(x),表示在结点x的状态下,没有到达目标状态下的正确位置的棋子的个
1
数。 请使用该估计函
数,对图示的初始状态,给出使用分支限界方法转换到目标状态的搜索树。 1 2 4 1 2 3 4 5 6 3 7 5 6 7 8 9 10 12
8 9 10 11 12 13 14 11 15 13 14 15 初始状态 目标状态
参考答案 一、名词解释: 1.算法:算法是指解决问题的一
种方法或一个过程。算法是若干指令的有穷序列,满足性质:(1)输入:有零个或多个外部量作为算法的输入;(2)输出:算法产生至少一个量作为输出;(3)确定性:组成算法的每条指令清晰、无歧义;(4)有限性:算法中每条指令的执行次数有限,执行每条指令的时间也有限。 2.程序:程序是算法用某种程序设计语言的具体实现。 3.递归函数:用函数自身给出定义的函数称为递归函数。 4.子问题的重叠性质:递归算法求解问题时,每次产生的子问题并不总是新问题,有些子问题被反复计算多次,这种性质称为子问题的重叠性质。 5.队列式分支限界法:队列式(FIFO)分支限界法是将活结点表组织成一个队列,并按照队列的先进先出(FIFO)原则选取下一个结点为扩展结点。 6.多机调度问题:多机调度问题要求给出一种作业调度方案,使所给的n个作业在尽可能短的时间内由m台机器加工处理完成。同时约定每个作业均可在任何一台机器上加工处理,但未完工前不允许中断处理。作业不能拆分成更小的子作业。 7.最小生成树:G=(V,E)是无向连通带权图,G的子图称为G的生成树,生成树上各边权的总和称为该生成树的耗费,在G的所有生成树中,耗费最小的生成树称为G的最小生成树。 二、简答题: 1.备忘录方法和动态规划算法相比有何异同?简述之。 备忘录方法是动态规划算法的变形。与动态规划算法一样,备