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

算法与设计A05_3.ppt

  1. 1、本文档共12页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
算法与设计A05_3

一、解的结构确定-----重排原理 在静态约束假设下,设第1层有m0个满足约束的结点。并且第1层上每个结点有m1个儿子结点满足约束。这样,第2 层就有m0 m1个满足约束的结点。同理,第3层上满足约束 的结点个数为m0 m1 m2。依此类推,可知第i+1层满足约束条件的结点个数为m0 m1 ….mi。 用回溯法解具体问题时,若要估计得更精确,可选取若干条不同的随机路径,分别对各随机路径估计结点的总数,然后再取这些结点总数的平均值,得到m的估计值。 第5章 回溯法 5.1 回溯法的算法框架 5.2 装载问题 5.3 回溯法的效率分析 本章主要知识点: * 5.2 装载问题 有一批共n个集装箱要装上2艘载重量分别为c1和c2的轮船,其中集装箱i的重量为wi,且 装载问题要求确定是否有一个合理的装载方案可将这n个集装箱装上这2艘轮船。如果有,找出一种装载方案。 容易证明,如果一个给定装载问题有解,则采用下面的策略可得到最优装载方案。 (1)首先将第一艘轮船尽可能装满; (2)将剩余的集装箱装上第二艘轮船。 将第一艘轮船尽可能装满等价于选取全体集装箱的一个子集, 使该子集中集装箱重量之和最接近c1。由此可知,装载问题等价 于以下特殊的0-1背包问题。 一、装载问题: 5.2 装载问题 引入上界函数用于减去不含最优解的子树: 当前载重量cw+剩余集装箱的重量r?当前最优载重bestw 三、算法改进: 构造最优解:引入 x和bestx,其中,x用于记录从根结点 至当前结点的路径,bestx记录当前的最优解。 5.2 装载问题 private static void backtrack (int i) {// 搜索第i层结点 if (i n) // 到达叶结点 { if (cwbestw) { for(j=1;j=n;j++) bestx[j]=x[j]; //更新最优解bestx bestw=cw; //更新最优值bestw } return; } r -= w[i]; if (cw + w[i] = c) {// 搜索左子树 x[i] = 1; cw += w[i]; backtrack(i + 1); cw -= w[i]; } if (cw + r bestw) { x[i] = 0; // 搜索右子树 backtrack(i + 1); } r += w[i]; } 改进算法如下: zhuangzaigaijin.java r初始化为所有的集装箱重量之和 5.2 装载问题 五、迭代回溯 利用数组x所含的信息,可以将前面的回溯法表示成 非递归形式。 //搜索树 while(true){ while(i=ncw+w[i]=c){//进入左子树 r-=w[i]; cw+=w[i]; x[i]=1; i++; } if(in){ //到达叶结点 for(int j=1;j=n;j++) bestx[j]=x[j]; bestw=cw;} else{ //进入右子树 r-=w[i];x[i]=0; i++; } while(cw+r=bestw){ i--;//剪枝回溯 while(i0x[i]==0){ r+=w[i]; i--; //从右子树返回} if(i==0) return bestw; x[i]=0;//进入右子树 cw=cw-w[i]; i++; } } zhuangzaidiedai.java 5.13 回溯法效率分析 通过前面具体实例的讨论容易看出,回溯算法的效率在很大程度上依赖于以下因素: (1)产生x[k]的时间; (2)满足显约束的x[k]值的个数; (3)计算约束函数constraint的时间; (4)计算上界函数bound的时间; (5)满足约束函数和上界函数约束的所有x[k]的个数。 好的约

文档评论(0)

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

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

1亿VIP精品文档

相关文档