0-1背包问题的算法设计策略对比与分析报告_第1页
0-1背包问题的算法设计策略对比与分析报告_第2页
0-1背包问题的算法设计策略对比与分析报告_第3页
0-1背包问题的算法设计策略对比与分析报告_第4页
0-1背包问题的算法设计策略对比与分析报告_第5页
免费预览已结束,剩余6页可下载查看

下载本文档

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

文档简介

1、式修理了火孚算法设计与分析大作业班 级:电子154姓 名:吴志勇学号:1049731503279任课老师:李瑞芳日期:2015.12.250-1背包问题的算法设计策略对比与分析0引言对于计算机科学来说,算法的概念是至关重要的。在一个大型软件系统的开发中,设计出有效的 算法将起到决定性的作用。通俗的讲,算法是解决问题的一种方法。也因此,算法分析与设计成为计算科学的核心问题之一,也是计算机科学与技术专业本科及研究生的一门重要的专业基础课。算法 分析与设计是计算机软件开发人员必修课,软件的效率和稳定性取决于软件中所采用的算法;对于一 般程序员和计算机专业学生,学习算法设计与分析课程,可以开阔编程思路

2、,编写出优质程序。通过 老师的解析,培养我们怎样分析算法的好“于 坏”,怎样设计算法,并以广泛用于计算机科学中的算法为例,对种类不同难度的算法设计进行系统的介绍与比较。本课程将培养学生严格的设计与分析算 法的思维方式,改变随意拼凑算法的习惯。本课程要求具备离散数学、程序设计语言、数据结构等先 行课课程的知识。1算法复杂性分析的方法介绍算法复杂性的高低体现在运行该算法所需要的计算机资源的多少上,所需的资源越多,该算法的复杂性越高;反之,所需资源越少,该算法的复杂性越低。 对计算机资源,最重要的是时间与空间(即存储器)资源。因此,算法的复杂性有时间复杂性T(n)与空间复杂性S(n)之分。算法复杂性

3、是算法运行所需要的计算机资源的量,这个量应集中反映算法的效率,并从运行该算 法的实际计算机中抽象出来,换句话说,这个量应该只依赖要解决的问题规模算法的输入和算法本 身的函数。用C表示复杂性,N,I和A表示问题的规模、算法的输入和算法本身规模,则有如下表达式:C=F(N,I,A) T=F(N , I,A) S=F(N , I,A)其中F(N,I,A)是一个三元函数。通常 A隐含在复杂性函数名当中,因此表达式中一般不写Ao即:C=F(N,I) T=F(N,I) S=F(N,I)算法复杂性中时间与空间复杂性算法相似,所以以下算法复杂性主要以时间复杂性为例:算法的时间复杂性一般分为三种情况:最坏情况、

4、最好情况和平均情况。下面描述算法复杂性时 都是用的简化的复杂性算法分析,引入了渐近意义的记号O,Q,。,和o。C表示渐近上界Q表示渐近下界:。表示同阶即:f ( n)= Qg(n)且 f(n)= Q ( g(n)2常见的算法分析设计策略介绍2.1递归与分治策略分治法的设计思想是,将一个难以直接解决的大问题,分割成一些规模较小的相同问题,以 便各个击破,分而治之。直接或间接地调用自身的算法称为递归算法。用函数自身给出定义的函数称为递归函数。由分治法产生的子问题往往是原问题的较小模式,这就为使用递归技术提供了方便。在这种情况下,反复应用分治手段,可以使子问题与原问题类型一致而其规模却不断缩小,最终

5、使子问 题缩小到很容易直接求出其解。这自然导致递归过程的产生。分治与递归像一对挛生兄弟,经常同时应用在算法设计之中,并由此产生许多高效算法。递归算法举例:Fibonacci 数歹U无穷数列1, 1, 2, 3, 5, 8, 13, 21, 34, 55,,称为Fibonacci数列。它可以递归地定义为:1n = 0F(n) = 1n = 1F(n -1) F(n -2) n 1第n个Fibonacci数可递归地计算如下:int fibonacci (int n)(if (n = 1) return 1;return fibonacci (n-1)+ fibonacci (n-2);从上看出:递

6、归算法的有点为:结构清晰,可读性强,而且容易用数学归纳法来证明算法的正确性,因此它为设计算法、 调试程序带来很大方便。缺点为:递归算法的运行效率较低,无论是耗费的计算时间还是占用的存储空间都比非递 归算法要多。分治算法:一个分治法将规模为n的问题分成k个规模为n/m勺子问题去解。设分解阀值 n0=1 ,且adhoc解 规模为1的问题耗费1个单位时间。再设将原问题分解为k个子问题以及用merge将k个子问题的解合 并为原问题的解需用f(n)个单位时间。用T(n)表示该分治法解规模为|P|=n的问题所需的计算时 间,则有:O(1)T(n)= kT(n/m) f (n)通过迭代法求得方程的解: 算法

7、举例:logmn-110g 一 kjjT(n) = n m kj f(n/mj)二分搜索技术:给定已按升序排好序的n个元素a0:n-1j0 ,现要在这n个元素中找出一特定元素X。据此容易设计出 二。搜索算法:template int BinarySearch(Type a口,const Type& x, int l, int r)(while (r = l)int m = (l+r)/2;if (x = am) return m;if (x am) r = m-1; else l = m+1;return -1;算法复杂度分析:每执行一次算法的while循环,待搜索数组的大小减少一半。因此,在

8、最坏情况下, while循环被执行了 O(logn)次。循环体内运算需要 0(1)时间,因此整个算法在最坏情况下 的计算时间复杂性为O(logn)。快速排序法:在快速排序中,记录的比较和交换是从两端向中间进行的,关键字较大的记录一次就 能交换到后面单元,关键字较小的记录一次就能交换到前面单元,记录每次移动的距离较大,因而总的比较和移动次数较少。void Quicksort (Type a, int p, int r) (if (Pr) int q=Partition(a,p,r);QuickSort (a,p,q-1); /对左半段排序QuickSort (a,q+1,r); /对右半段排序

9、复杂性分析: 最坏时间复杂度:O(n2)平均时间复杂度:O(nlogn) 辅助空间:O(n)或O(logn)2.2 动态规划动态规划算法与分治法类似,其基本思想也是将待求解问题分解成若干个子问题但是经分解 得到的子问题往往不是互相独立的。不同子问题的数目常常只有多项式量级。在用分治法求解时, 有些子问题被重复计算了许多次。如果能够保存已解决的子问题的答案,而在需要时再找出已求得 的答案,就可以避免大量重复计算,从而得到多项式时间算法。方法步骤:1 )找出最优解的性质,并刻划其结构特征。2)递归地定义最优值。3)以自底向上的方式计算出最优值。4)根据计算最优值时得到的信息,构造最优解。举例:矩阵

10、连成问题基本要素:1)最优子结构2)重叠子问题3)备忘录方法将矩阵连乘积简记为Ai:j,这里i wj考察计算Ai:j的最优计算次序。设这个计算次序在矩阵Ak和Ak+1之间将矩阵链断开,i wkj ,则其相应完全加括号方式为:(AA书.人)(入引八七.3)计算量:Ai:k的计算量加上 Ak+1:j的计算量,再加上Ai:k和Ak+1:j相乘的计算量。算法如下:void MatrixChain(int *p , int n , int *m , int *s) (for (int i = 1; i = n; i+) mii = 0;for (int r = 2; r = n; r+)for (int

11、 i = 1; i = n - r+1; i+) int j=i+r-1;mij = mi+1j+ pi-1*pi*pj;sij = i;for (int k = i+1; k j; k+) int t = mik + mk+1j + pi-1*pk*pj;if (t mij) mij = t; sij = k;算法复杂度分析:算法matrixChain的主要计算量取决于算法中对r, i和k的3重循环。循环体内的计算量为O(1),而3重循环的总次数为O(n3)。因此算法的计算时间上界为O(n3)。算法所占用的空间显然为 O(n2)。2.3 贪心算法顾名思义,贪心算法总是作出在当前看来最好的选择

12、。也就是说贪心算法并不从整体最优考虑,它所作出的选择只是在某种意义上的局部最优选择。当然,希望贪心算法得到的最终结果也是 整体最优的。虽然贪心算法不能对所有问题都得到整体最优解,但对许多问题它能产生整体最优解。 如单源最短路经问题,最小生成树问题等。在一些情况下,即使贪心算法不能得到整体最优解,其 最终结果却是最优解的很好近似。可用贪心算法解决的问题的性质:1)贪心选择性质2)最优子结构性质举例:最优装载问题有一批集装箱要装上一艘载重量为c的轮船。其中集装箱i的重量为Wio最优装载问题要求确定在装载体积不受限制的情况下,将尽可能多的集装箱装上轮船。 算法描述最优装载问题可用贪心算法求解。采用重

13、量最轻者先装的贪心选择策略,可产生最优装 载问题的最优解。具体算法描述如下。templatevoid Loading (int x, Type w口,Type c, int n)int *t = new int n+1;Sort(w, t, n);for (int i = 1; i = n; i+) xi = 0;for (int i = 1; i = n & wti half)|(t*(t-1)/2-counthalf) return;if (tn) sum+;elsefor (int i=0;i2;i+) p1t=i;count+=i;for (int j=2;j=t;j+) pjt-j+

14、1=pj-1t-j+1Apj-1t-j+2;count+=pjt-j+1;)Backtrack(t+1);for (int j=2;j=t;j+)count-=pjt-j+1;count-=i;复杂度分析计算可行性约束需要 O(n)时间,在最坏情况下有O(2n)个结点需要计算可行性约束,故解符号三角形问题的回溯算法所需的计算时间为O(n2n)。2.5分支限界法分支限界法常以广度优先或以最小耗费(最大效益)优先的方式搜索问题的解空间树。在分支限界法中,每一个活结点只有一次机会成为扩展结点。活结点一旦成为扩展结点,就一 次性产生其所有儿子结点。在这些儿子结点中,导致不可行解或导致非最优解的儿子结点

15、被舍弃, 其余儿子结点被加入活结点表中。此后,从活结点表中取下一结点成为当前扩展结点,并重复上述结点扩展过程。这个过程一 直持续到找到所需的解或活结点表为空时为止。常见的两种分支限界法:(1)队列式(FIFO)分支限界法按照队列先进先出(FIFO)原则选取下一个节点为扩展节点。(2)优先队列式分支限界法按照优先队列中规定的优先级选取优先级最高的节点成为当前扩展节点。举例:0-1背包问题算法思想:首先,要对输入数据进行预处理,将各物品依其单位重量价值从大到小进行排列。在下面描述的优先队列分支限界法中,节点的优先级由已装袋的物品价值加上剩下的最大单位重量价值的物品装满剩余容量的价值和。算法首先检查

16、当前扩展结点的左儿子结点的可行性。如果该左儿子结点是可行结点,则将 它加入到子集树和活结点优先队列中。当前扩展结点的右儿子结点一定是可行结点,仅当右儿子 结点满足上界约束时才将它加入子集树和活结点优先队列。当扩展到叶节点时为问题的最优值。 部分算法如下:while (i != n+1) /非叶结点/检查当前扩展结点的左儿子结点Typew wt = cw + wi;if (wt bestp) bestp = cp+pi;AddLiveNode(up, cp+pi, cw+wi, true, i+1);up = Bound(i+1);/检查当前扩展结点的右儿子结点if (up = bestp) /

17、右子树可能含最优解AddLiveNode(up, cp, cw, false, i+1);/取下一个扩展节点(略)3结合0-1背包问题详述动态规划、贪心算法、回溯法、分支限界法解决问题的过程0-1背包问题: 给定n#物品和一背包。物品i的重量是wi,其价值为vi ,背包的容量为Co问应如 何选择装入背包的物品,使得装入背包中物品的总价值最大?动态规划算法:n设所给0-1背包问题的子问题max z vk xkk =i, n WkXk & jk =iXk 0,1, i k 三 n的最优值为m(i , j),即m(i , j)是背包容量为j ,可选择物品为i , i+1 ,,n 时0-1背包问题的最

18、优值。由0-1背包问题的最优子结构性质,可以建立计算m(i, j)的递归式如下。m(i, j)=max m(im(i 1, j)0 - jwim(n, j);算法复杂度分析:vr0j - Wn0 M jWn1, j),m(i 1, j - Wi) Vij - Wic很大时,算法需要从m(i, j)的递归式容易看出,算法需要 O(nc)计算时间。当背包容量 的计算时间较多。例如,当c2n时,算法需要Q(n2n)计算时间。改进算法:由m(i,j)的递归式容易证明,在一般情况下,对每一个确定的i(1 &i &n),函数m(i,j) 是关于变量j的阶梯状单调不减函数。跳跃点是这一类函数的描述特征。在一

19、般情况下, 函数m(i,j)由其全部跳跃点唯一确定。对每一个确定的i(1 & i & n),用一个表pi存储函数m(i , j)的全部跳跃点。表pi可依计算m(i , j)的递归式递归地由表pi+1计算,初始时 pn+1=(0 , 0)。函数m(i,j)是由函数m(i+1,j)与函数m(i+1,j-wi)+vi作maxi算得到的。因此,函数m(i,j)的全部跳跃点包含于函数m(i+1 , j)的跳跃点集pi+1与函数m(i+1 ,j-wi)+vi 的跳跃点集qi+1的并集中。易知,(s,t) eqi+1当且仅当wiMsc且 (s-wi,t-vi) Wpi+1。因此,容易由pi+1 向定跳跃点集

20、qi+1 如下qi+1=pi+1二(wi,vi尸(j+wi,m(i,j)+vi)|(j,m(i,j)pi+1另一方面,设(a, b)和(c, d)是pi+1 =qi+1中的2个跳跃点,则当 6 a且db 时,(c , d)受控于(a, b),从而(c , d)不是pi中的跳跃点。除受控跳跃点外, pi+1 =qi+1中的其它跳跃点均为pi中的跳跃点。由此可见,在递归地由表pi+1计算表pi时,可先由pi+1计算出qi+1,然 后合并表pi+1和表qi+1,并清除其中的受控跳跃点得到表pi。改进后复杂性分析:上述算法的主要计算量在于计算跳跃点集pi(1 i n) 0由于qi+1=pi+1畲(wi

21、 ,vi),故计算 qi+1需要 O(|pi+1|) 计算时间。合并 pi+1和qi+1 并消除受控跳跃点也需要O(|pi+1|)计算时间。从跳跃点集pi的定义可以看出,pi中的跳跃点相应于xi,xn的0/1赋值。因此,pi中跳跃点个数不超过2n-i+1。由此可 见,算法计算跳跃点集pi所花费的计算时间为 从而,改进后算法的计算时间复杂性为 O(2n)。当所给物品的重量wi(1 &i&n)是整数时, |pi|c+1,(1 i n)0在这种情况下,改进后算法的计算时间复杂性为 O(minnc,2n)。贪心算法:在选择装入背包的物品时,对每种物品i只有2种选择,即装入背包或不装入背包。不 能将物品i装入背包多次,也不能只装入部分的物品i。贪心算法的两条性质,可以放入物 品的部分,使它适合背包问题。不适合 0-1背包问题,所以不能用贪心算法计算。 回溯法: 回溯法的三个条件: 解空间:子集树n可行性约束函数:、wi xi - C1i =1上界函数:templateTypep Knap二 BoundQnt i)/计算上界Typew cleft = c - cw; /乘 U 余容量Typep b =

温馨提示

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

评论

0/150

提交评论