网站大量收购闲置独家精品文档,联系QQ:2885784924

《回溯法设计的运用和发展.ppt

  1. 1、本文档共57页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
基本内容 用计算机求解问题 计算机求解的过程 在状态空间寻找机内解可以看成是从初始状态出发搜索目标状态(解所在的状态)的过程。 求解是状态空间的搜索 求解的过程可以描述为对状态空间的搜索 几种搜索方法 三种搜索的优劣之处 一般来说,三种搜索方法各有优劣之处: 广度优先搜索的优点是一定能找到解;缺点是空间复杂性和时间复杂性都大。 深度优先搜索的优点是空间复杂性和时间复杂性较小;缺点是不一定能找到解。 启发式搜索的是最好优先的搜索,优点是一般来说能较快地找到解,即其时间复杂性更小;缺点是需要设计一个评价函数,并且评价函数的优劣决定了启发式搜索的优劣。 三种搜索的不同之处 其中,深度优先搜索就是回溯法。 什么是回溯法 回溯法实际是穷举算法,按问题某种变化趋势穷举下去,如某状态的变化用完还没有得到最优解,则返回上一种状态继续穷举。回溯法有“通用的解题法”之称,其采用了一种“走不通就掉头”思想作为其控制结构,用它可以求出问题的所有解和任意解。 它的应用很广泛,很多算法都用到回溯法,例如,图的深度优先算法,最短路径算法,骑士巡游算法,八皇后问题,N重循环等都用到回溯法,当然其中还使用了其他策略。 回溯法的一般形式 Try(s){ 做挑选候选者的准备; while (未成功且还有候选者) { 挑选下一个候选者next; if (next可接受) { 记录next; if (满足成功条件) {成功并输出结果} else Try(s+1); if (不成功) 删去next的记录; }} return 成功与否} 解空间树(Solution Space Tree) 解空间的组织(Tree Organization Of Solution Space) 任何时候,在构造问题解的时候,都包含做出一系列的决策, 如果我们将做出的决策画出来,这个图就象一棵树.建立一个树型结构, 使得树叶对应解空间的一个解,而内部节点的一个分支,对应一个决策,这样,便可以将解空间组织为一棵解空间树. 回溯法可以很容易地被用来搜索一个集合的所有子集合或是排列.. 当我们要解决的问题是要求一个使问题最优的n个元素的子集, 问题的解空间常可以组织成一棵子集树 构造所有的子集 n个元素的集合有多少个子集? ? 如果每个 Si 的大小是 k, 对每个 xi∈Si ,共有 kn 个子集 子集树 子集树(Subtree) 货箱装载问题 问题 给定n个货箱,货箱i 重为 wi. 船可以装载的货箱总重量为 W. 货箱装载问题是在不使船翻的前提下装载尽可能多的货箱. 解空间 假设解可以由向量 (x1,x2,…,xn)表示, xi∈{0,1}, xi =1 表示货箱 i 被装上船, xi =0表示货箱 i 不装上船. 货箱装载问题可以形式地描述如下: 解空间树 有 2n 个叶子的子集树 在第 j层, 节点的展开由 xj+1的值决定. Subtree: n=4 约束函数 令 cw(i) 表示到第 i层的当前重量, 记为 则约束函数为 剪枝 若 ,则停止搜索第 i层及其下面的层, 否则,继续搜索. 对 n=4,w=[8,6,2,3], W=12进行回溯 回溯递归版本 Backtrack(t) 1 if (tn) then 2 if (cwbestw) then bestw←cw 3 return 4 else 5 if (C(t) ≤W )then 6 cw←cw+w[t] 7 Backtrack(t+1) 8 cw←cw-w[t] 9 Backtrack(t+1) 改进的回溯算法 利用限界函数 其中, r(j) 表示剩余货箱的总重量 剪枝 若 , 则停止搜索第 i 层及其下面的层, 否则,继续搜索. 其中, bestw 表示目前为止所得到的最佳重量 对 n=4,w=[8,6,2,3], W=12进行回溯 0-1 背包问题 问题 给定 n 个物品, 物品 i 重 wi ,价值 vi ,背包可以承受的物品的总重最大为 W. 0-1 背包问题的目的是要选择一个物品的子集,使其总重量 ≤W而价值最大. 解空间 假设解可以由向量 (x1,x2,…,xn)表示, xi∈{0,1}, xi

文档评论(0)

you9391 + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档