第六节回溯法.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
计算机算法设计与分析 North China Electric Power University Computer Algorithms Design Analysis 华北电力大学计算机科学与工程系 Dept. of Computer ScienceEngineering of North China Electric Power University 第六章 回溯算法(Backtracking Algorithm) ★ 回溯法的算法框架 ★ 自然数的排列问题 ★ 婚姻搭配问题 ★ n后问题 ★ 图的着色问题 North China Electric Power University ★ 旅行售货员问题 ★ 符号三角形问题 §1 回溯法的算法框架 North China Electric Power University 回溯法是一个既带有系统性又带有跳跃性的的搜索算法。回溯法在包含问题的所有解的解空间树中,按照深度优先的策略,从根结点出发搜索解空间树。算法搜索至解空间树的任何一个结点时,总是先判断该结点是否肯定不包含问题的解,如果肯定不包含,则跳过对以该结点为根的子树搜索。否则,进入该子树,继续按深度优先的策略进行搜索。 回溯法在用来求问题的所有解时,要回溯到根,且根结点的所有子树都已被搜索遍才结束。而回溯法在用来求问题的任一解时,只要搜索到问题的一个解就可结束。 North China Electric Power University 1.问题的解空间: 应用回溯法解问题时,首先应明确定义问题的解空间。问题的解空间应至少包含问题的一个最优解。例如,对于有n种可选择的物品的0-1背包问题,其解空间由长度为n的0-1向量组成。该解空间包含了对变量的所有可能的0-1赋值。例如,当n=3时,其解空间{(0,0,0),(0,1,0),(0,0,1),(1,0,0), (0,1,1),(1,0,1),(1,1,0),(1,1,1)}。 A B C D E F G H I J L K M N O 1 0 1 0 1 0 1 0 1 0 1 0 1 0 通常将问题的解空间组织成树或图的形式。例如,对于n=3的0-1背包问题,其解空间树可用下面的完全二叉树表示。 North China Electric Power University 2.回溯法的基本思想: 确定了解空间的组织结构后,回溯法就从开始结点(根结点)出发,以深度优先搜索的方式搜索整个解空间。这个开始结点就成为一个活结点,同时也成为当前的扩展结点。在当前的扩展结点处,搜索向纵深方向移至一个新结点。这个新结点就成为一个新的活结点,并成为当前扩展结点。如果在当前的扩展结点处不能再向纵深方向移动,则当前的扩展结点就成为死结点。此时,应往回移动(回溯)至最近的一个活结点处,并使这个活结点成为当前的扩展结点。回溯法即以这种工作方式递归地在解空间中搜索,直至找到所要求的解或解空间中已无活结点时为止。 在用回溯法搜索解空间树时,通常采用两种策略来避免无效搜索,提高回溯法的搜索效率。其一是用约束函数在扩展结点处剪去不满足约束条件的子树;其二是用限界法剪去不能得到最优解的子树。这两类方法统称为剪枝函数。 A B C D E F G I L K M N O x1=1 x1=0 x2=1 x2=0 H x3=1 x3=0 J x3=1 x3= 0 x2=1 x2=0 x3=1 x3=0 x3=1 x3=0 例:0-1背包问题 n=3,C=20,(p1,p2,p3)=(20,15,25) (w1,w2,w3)=(10,5,15),求X=(x1,x2,x3)使背包价值最大? (10,20) (15,35) (15,35) (10,20) (10,20) (5,15) (20,40) (15,35) (5,15) (20,40) (0,0) (0,0) (15,25) (20,40) (20,40) (0,0) (20,40) 当前最优解 可行解 中间计算结果 综上所述,运用回溯法解问题通常包含以下三个步骤: 1)针对所给问题,定义问题的解空间; 2)确定易于搜索的解空间结构 3)以深度优先的方式搜索解空间,并且在搜索过程中用剪枝函数避免无效搜索。 3.递归回溯: 由于回溯法是对解空间的深度优先搜索,因此在一般情况下可用递归函数来实现回溯法如下: void Backtrack(int t) { if(tn) Output(x); else for(int i=f(n,t);i=g(n,t);i++) // f(n,t)和g(n,t):在当前扩展结点处未搜索过的子树

文档评论(0)

kehan123 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档