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

第5章回溯法.ppt

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

* 这3个作业的6种可能的调度方案是1,2,3;1,3,2;2,1,3;2,3,1;3,1,2;3,2,1;它们所相应的完成时间和分别是19,18,20,21,19,19。显而易见,最佳调度方案是1,3,2,其完成时间和为18。 tji 机器1 机器2 作业1 2 1 作业2 3 1 作业3 2 3 例如,考虑如下n=3 的实例: * tji 机器1 机器2 作业1 2 1 作业2 3 1 作业3 2 3 public class FlowShop static int n, // 作业数 f1, // 机器1完成处理时间 f, // 完成时间和 bestf; // 当前最优值 static int [][] m; // 各作业所需的处理时间 static int [] x; // 当前作业调度 static int [] bestx; // 当前最优作业调度 static int [] f2; // 机器2完成处理时间 tji 机器1 机器2 作业1 2 1 作业2 3 1 作业3 2 3 * 算法设计 批处理作业调度问题要从n个作业的所有排列中找出有最小完成时间和的作业调度,所以批处理作业调度问题的解空间是一棵排列树。按照回溯法搜索排列树的算法框架,设开始时x=[1,2,…,n]是所给的n个作业,则相应的排列树由x[1:n]的所有排列构成。 类Flowshop的数据成员记录解空间树中结点信息,以减少传给backtrack的参数。二维数组m是输入的作业处理时间,m[i][1]代表i作业在1机器上的加工时间, m[i][2]代表i作业在2机器上的加工时间。bestf 记录当前最小完成时间和,bestx 是相应的当前最佳作业调度。 * 在递归方法backtrack中,当in 时,算法搜索至叶结点,得到一个新的作业调度方案。此时算法适时更新当前最优值和相应的当前最佳作业调度。 当in时,当前扩展结点位于排列树的第i-1层。此时算法选择下一个要安排的作业,以深度优先的方式递归地对相应子树进行搜索。对于不满足上界约束的结点,则剪去相应的子树。 * 批处理作业调度 解空间:排列树 private static void backtrack(int i) { if (i n) { for (int j = 1; j = n; j++) bestx[j] = x[j]; bestf = f; } else for (int j = i; j = n; j++) { f1+=m[x[j]][1]; f2[i]=((f2[i-1]f1)?f2[i-1]:f1)+m[x[j]][2]; f+=f2[i]; if (f bestf) { MyMath.swap(x,i,j); backtrack(i+1); MyMath.swap(x,i,j); } f1-=m[x[j]][1]; f-=f2[i]; } } public class FlowShop static int n, // 作业数 f1, // 机器1完成处理时间 f, // 完成时间和 bestf; // 当前最优值 static int [][] m; // 各作业所需的处理时间 static int [] x; // 当前作业调度 static int [] bestx; // 当前最优作业调度 static int [] f2; // 机器2完成处理时间 * 该问题关键是求作业在机器2上的完成处理时间,从28页的图可以看出,由于作业调度的顺序不同,每个作业在机器1上的开始时间不同,但由于机器1从一开工就对各个作业连续处理,因此作业i的机器的加工开始时间,就是它前面被加工作业的机器1上的处理时间之和。机器2对各个作业的加工,由于调度的差异会造成不连续,产生等待时间,也就是说,前一个作业的机器2的加工时间,大于后一个作业的机器1的加工时间时,后一个作业必须等

文档评论(0)

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

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

1亿VIP精品文档

相关文档