算法设计与分析第八章分枝限界法

算法设计与分析第八章分枝限界法

ID:41576820

大小:92.68 KB

页数:16页

时间:2019-08-28

算法设计与分析第八章分枝限界法_第1页
算法设计与分析第八章分枝限界法_第2页
算法设计与分析第八章分枝限界法_第3页
算法设计与分析第八章分枝限界法_第4页
算法设计与分析第八章分枝限界法_第5页
资源描述:

《算法设计与分析第八章分枝限界法》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

1、第八章分枝一限界法§1算法基本思想本章叙述中为了区别图中的顶点和解空间树中的顶点,凡是在解空间树中出现的“顶点”一律称为“结点”。分枝限界法同冋溯法类似,它也是在解空间中搜索问题的可行解或最优解,但搜索的方式不同。回溯法采用深度优先的方式,朝纵深方向搜索,直至达到问题的一个可行解,或经判断沿此路径不会达到问题的可行解或最优解时,停止向前搜索,并沿原路返回到该路径上最后一个还可扩展的结点。从该结点出发朝新的方向纵深搜索。分枝限界法则采用宽度优先的方式搜索解空间树,它将活结点存放在一■个特殊的表中。其策略是:在扩展结点处,首先生成其所有

2、的儿子结点,将那些导致不可行解或导致非最优解的儿子舍弃,其余儿子加入活结点表中。然后,从活结点表中取出一个结点作为当前扩展结点。重复上述结点扩展过程。所以,分枝限界法与冋溯法的本质区别在于搜索方式的不同。冋溯法更适于处理那些求所冇可行解的问题,而分枝限界法更适于处理那些只确定一个可行解,特别是最优解的问题。从活结点表中选择下一扩展结点的不同方式导致不同的分枝限界法。最常见的有以下两种方式:1).队列式(FIFO)分枝限界法:将活结点表组织成一个队列,并按队列的先进先出原则选取下一个结点作为当前扩展结点。2).优先队列式分枝限界法:将

3、活结点表组织成一个优先队列,并按优先队列给结点规定的优先级选取优先级最高的下一个结点作为当前扩展结点。队列式分枝限界法搜索解空间树的方式类似于解空间树的宽度优先搜索,不同的是队列式分枝限界法不搜索不可行结点(己经被判定不能导致可行解或不能导致最优解的结点)为根的子树。这是因为,按照规则,这样的结点未被列入活结点表。优先队列式分枝限界法的搜索方式是根据活结点的优先级确定下一个扩展结点。结点的优先级常用一个与该结点有关的数值p来表示。最大优先队列规定P值较犬的结点的优先级较高。在算法实现时通常用一个最大堆来实现最大优先队列,用最大堆的D

4、eletemax运算抽取堆中的下一个结点作为当前扩展结点,体现最犬效益优先的原则。类似地,最小优先队列规定p值较小的结点的优先级较高。在算法实现时,常用一个最小堆來实现,用最小堆的Deletemin运算抽取堆中下一个结点作为当前扩展结点,体现最小优先的原则。采用优先队列式分枝限界算法解决具体问题时,应根据问题的特点选用最大优先或最小优先队列,确定各个结点的P值。例1・1旅行商问题,沪4,其解空间树是一棵排列树。如文档“旅行商搜索树”。赋权图G给出如2求赋权图G的具有最小权的Hamilton圈采用队列式分枝限界法以排列树小的结点B作为

5、初始扩展结点。此时,活结点队列为空。由于从图G的顶点1到顶点2、3和4均有边相连,B的儿了C、D和E都是可行结点,它们被依次加入到活结点队列小,并舍弃当前扩展结点当前活结点队列中的队首结点C成为卜•一个扩展结点。由于图G的顶点2到顶点3和4有边相连,故结点C的二个儿子F和G均为可行结点,可以加入活结点队列。接卜'來,结点D和结点E相继成为扩展结点。此时活结点队列中的结点依次为F、G、H、I、J、Ko结点F成为下一个扩展结点,但其儿子L是解空间树的叶结点,我们找到了一条Hamilton®

6、(1,2,3,4,1),其费用为59。此时记录

7、这个口标函数值仁59。下一个扩展结点G的儿子M也是叶结点,得到另-•条Ham订ton圈(1,2,4,3,1),其费用为66。结点H成为当前扩展结点,其儿子N也是叶结点,得到第三条Ham订ton圈,其费用为25,因为它比记录屮的口标函数值还小,所以修改目标函数值记录:f=25o下一个扩展结点是I,由于从根结点到结点I的费用26已经超过口标函数的当前值,故没有必要扩展I,以I为根的了树被剪掉。最后J和K被依次扩展,活结点队列成为空集,算法终止。算法搜索到的最优值是25,相应的最优解是从根结点到结点N的路径(1,3,2,4,l)o采用优先

8、队列式分枝限界法,用一个最小堆存储活结点表,优先级函数值是结点的当丽费用。算法还是从排列树的结点B和空优先队列开始。结点B被扩展后,它的3个儿子C、D和E被依次插入堆屮。此时,由于E是堆小具有最小当前费用(为4)的结点,所以处于堆顶的位置,它自然成为下一个扩展结点。结点E被扩展后,其儿子J和K被插入当前堆中,它们的费用分别为14和24。此时,堆顶元素是D,它成为卜•一个扩展结点。它的2个儿了II和I被插入堆中。此时,堆中元素是结点C、H、I、J、Ko在这些结点小,H具有最小费用,成为下一个扩展结点。扩展结点II后得到一条Hamilt

9、on圈(1,3,2,4,1),相应的费用为25。接下来,结点J成为扩展结点,并由此得到一条Hamilton圈(1,4,2,3,1),费用仍为25。此后的两个扩展结点是K和I。由结点K得到的Hamilton圈的费用高于当前所知最小费用,

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。