+分支限界法【DOC精选】.docVIP

  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文档。上传文档
查看更多
分支限界法【DOC精选】

第七章分支限界法 假设旅行商问题的邻接矩阵如图1所示,试用优先队列式分枝限界算法给出最短环游。画出解空间树的搜索图,并说明搜索过程。 图1 邻接矩阵 图2 旅行商问题 解答: 搜索的过程如下: B{E,F,C,D} E{F,G,H,C,I,D} F{J,G,H,K,C,I,L,D} J{G,H,N,K,C,I,L,M,D} G{H,P,N,K,C,I,L,M,D,O} H{P,N,K,C,I,L,R,M,D,O,Q} P{N,K,C,I,L,R,M,D,O,Q} N{K,C,I,L,R,M,D,O,Q} K{C,I,L,R,V,M,D,O,Q,U} C{I,Y,L,R,V,X,M,D,O,Q,U,W} I{Y,L,R,V,X,Z,M,ZA,D,O,Q,U,W} Y{L,R,V,X,Z,M,ZA,ZB,D,O,Q,U,ZC,W} L{R,V,X,Z,ZD,M,ZA,ZB,ZE,D,O,Q,U,ZC,W} R{ V,X,Z,ZD,M,ZA,ZB,ZE,D,O,Q,U,ZC,W } V{ X,Z,ZD,M,ZA,ZB,ZE,D,O,Q,U,ZC,W } X{Z,ZD, M,ZA,ZB,ZE,D,O,ZH,Q,U,ZC,W } Z{ ZD, M,ZA,ZB,ZE,D,O,ZH,Q,U,ZC,W } ZD{ M,ZA,ZB,ZE,D,O,ZH,Q,U,ZC,W } M{ZA,ZB,ZE,D,O,ZH,Q,U,ZC,W } ZA{ ZB,ZE,D,O,ZH,Q,U,ZC,W } ZB{ ZE,D,O,ZH,Q,U,ZC,W } ZE{ D,O,ZH,Q,U,ZC,W } D{O,ZH,Q,U,ZC,W,ZQ,ZR,ZP} O{ ZH,Q,U,ZC,W,ZQ,ZR,ZP } ZH{ Q,U,ZC,W,ZQ,ZR,ZP } Q{ U,ZC,W,ZQ,ZR,ZP } U{ZC,W,ZQ,ZR,ZP} ZC{W,ZQ,ZR,ZP} W{ZQ,ZR,ZX,ZY,ZP} ZQ{ZR,ZZ,ZX,ZY,ZP,ZZA} ZR{ZZB,ZZ,ZX,ZY,ZP,ZZA,ZZC} ZZB{ZZ,ZX,ZY,ZP,ZZA,ZZC} ZZ{ ZX,ZY,ZP,ZZA,ZZC } ZX{ZY,ZP,ZZA,ZZC} ZY{ ZP,ZZA,ZZC } ZP{ZZA,ZZC} ZZA{ZZC} ZZC{} 下面的解答为一典型的错误解答。 (注意:此解答,最后一行,遗漏了返回出发点的最后一段的费用) 试写出0/1背包问题的优先队列式分枝限界算法程序,并找一个物品个数是16的例子检验程序的运行情况。 (具体程序见附件,但理解思想是关键) 最佳调度问题:假设有个任务要由个可并行工作的机器来完成,完成任务需要的时间为。试设计一个分枝限界算法,找出完成这个任务的最佳调度,使得完成全部任务的时间最短。 解: 思路一: 算法执行步骤如下: 1.先将任务由大到小排序 2.计算n个任务需要的总时间和平均到k个机器上的时间 3.将大于平均时间的任务各分配一个机器,找到最大完成时间 4.将其他任务顺序安排在一台机器上,如果时间超出最大时间,则把该任务交给下一个机器,下一个任务继续在这台机器上试安排,直到所有任务都不能在小于最大完成时间的情况下安排 5.安排下一台机器直到所有任务安排完, 6.或有可能安排某些任务找不到小于最大完成时间 那么重新扫描各台机器使再加上该任务后时间最小,按此方法安排完所有任务。 思路二: 将n个任务按照所需时间非递减排序,得到任务序列1,2,3,4…….,n,满足时间关系t[1]t[2]……t[n].然后将n个任务中的k个任务分配给当前k个机器,然后将第k+1个任务分配给最早完成已分配任务的机器,依次进行,最后找出这些机器最终分配任务所需时间最长的,此时间作为分支限界函数,如果一个扩展节点所需的时间超过这个已知的最优值,则删掉以此节点为根的子树。否则更新最优值。接下来采用优先队列分支限界算法。在活节点表中节点的优先级问题。优先级:哪台机器完成当前任务的时间越早,也就是所有机器中最终停机时间越早,优先级就越高,即被选作最小堆中的堆顶,作为扩展节点。 每个节点具有信息: {Parent:父亲节点,Level:节点所在深度加1,Ctime:运行到当前节点所用时间} 当level=k时(不能用界限函数来剪枝,也不需要判断优先级),由于机器还未装满(即

文档评论(0)

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

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

1亿VIP精品文档

相关文档