ImageVerifierCode 换一换
格式:DOC , 页数:16 ,大小:151.50KB ,
资源ID:234729      下载积分:15 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/234729.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(分支与限界货物装载问题.doc)为本站会员(b****1)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

分支与限界货物装载问题.doc

1、 分支与限界:货物装载问题课程名称: * 院 系: * 学生姓名: * 学 号: * 专业班级: *指导教师: * 2013年12月27日第 16 页 共 16 页分支与限界:货物装载问题摘要:在现实生活中,我们会经常遇见货物装载问题,如何解决货物装载问题,获取利润的最大化,花费最少的而得到更多的东西,是人们一直都要考虑的问题。在广泛的解决问题中,人们一般采用分支限界算法解决这样的问题。分支限界法是由分支策略和限界策略两部分组成的。分枝定界法是一个用途十分广泛的算法,运用这种算法的技巧性很强,不同类型的问题解法也各不相同。该算法在具体执行时,把全部可行的解空间不断分割为越来越小的子集(称为分支

2、),并为每个子集内的解的值计算一个下界或上界(称为定界)。在每次分支后,对凡是界限超出已知可行解值那些子集不再做进一步分支。这样,解的许多子集(即搜索树上的许多结点)就可以不予考虑了,从而缩小了搜索范围。该算法在具体执行时,把全部可行的解空间不断分割为越来越小的子集(称为分支),并为每个子集内的解的值计算一个下界或上界(称为定界)。在每次分支后,对凡是界限超出已知可行解值那些子集不再做进一步分支。这样,解的许多子集(即搜索树上的许多结点)就可以不予考虑了,从而缩小了搜索范围。分支策略体现在对问题空间是按广度优先的策略进行搜索,限界策略是为了加速搜索速度而采用启发信息剪枝的策略。在分支限界法,经

3、常采用的是分支搜索法,分支搜索法是一种在问题空间上进行搜索尝试的算法。所谓分支是采用广度优先的策略,依次搜索E-结点的所有的分支,也就是所有的相邻结点。和回溯法一样,在生成的节点中,抛弃那些不满足的约束条件的的结点,其余结点加入活结点表。在分支搜索的算法中,人们经常会采用FIFO搜索和优先队列式搜索。例题中采用的是轮船装载的问题,这是一个非常经典的分支限界算法的例题,通过这个例子的学习,将会理解并掌握分支限界货物装载的问题。关键词:分支限界法 货物装载 FIFO分支限界 优先队列分支限界 目录第一章 绪论41.1分支-界限算法的基本思想41.2常见的两种分支界限算法4第二章 货物装载问题52.

4、1 问题描述52.2 问题分析5第三章 优先队列式分支限界法解决货物装载问题63.1 算法设计63.2 数据结构设计73.2.1程序流程图73.2.2 数据结构描述73.2.3 重要算法83.3 测试结果与分析9第四章 基于队列式(FIFO)分支限界法解决货物装载问题104.1 算法设计104.2 数据结构设计104.2.1程序流程图114.2.2 数据结构描述和算法114.3 测试结果与分析13第五章 结论14参考文献15第一章 绪论1.1分支-界限算法的基本思想分支限界法常以广度优先或以最小耗费(最大效益)优先的方式搜索问题的解空间树。在分支限界法中,每一个活结点只有一次机会成为扩展结点。

5、活结点一旦成为扩展结点,就一次性产生其所有儿子结点。在这些儿子结点中,导致不可行解或导致非最优解的儿子结点被舍弃,其余儿子结点被加入活结点表中。此后,从活结点表中取下一结点成为当前扩展结点,并重复上述结点扩展过程。这个过程一直持续到找到所需的解或活结点表为空时为止。1.2常见的两种分支界限算法 队列式(FIFO)分支限界法按照队列先进先出(FIFO)原则选取下一个节点为扩展节点。FIFO搜索算法要依赖“队”做基本的数据结构。一开始根节点是唯一的活结点,根节点入队。从活结点的对中取出艮结点后,作为当前扩展结点。对当前扩展结点,先从左到右地产生它的所有儿子,用约束条件检查,把所有满足约束函数的儿子

6、加入到活结点队列中。再从活结点表中取出队首结点为当前扩展结点。优先队列式分支限界法按照优先队列中规定的优先级选取优先级最高的节点成为当前扩展节点。优先队列式搜索,对每一个活结点计算一个优先级,并根据这些优先级,从当前活结点表中优先选择一个一个优先级最高的节点作为扩展结点,使搜索朝着解空间树上最优解的分支推进,以便尽快找出一个最优解。第二章 货物装载问题2.1 问题描述有两艘船和需要装运的N个货箱,第一艘船的载重量是c1,第二艘船的载重量是c2,wi是货箱i的重量,且w1+w2+.+wn=c1+c2。希望确定是否有一种可能将所有货箱全部装船的方法。若有的话,找出该方法。2.2 问题分析先看一个实

7、例,当n=3,c1=c2=50,w=10,40,40时,可将货箱1,2装到第一艘船上,货箱3装到第二艘船上。但如果w=20,40,40,则无法将货箱全部装船。有此可知问题可能有解,可能无解,也可能多解。虽然是关于两艘船的问题,若w1+w2+w3+.wn-bestw 0; j-) rj=rj+1 + wj+1; int i = 1; bbnode *E = 0; Ew = 0; / 搜索子集空间树 while (i != n+1) / 不在叶子上 if (Ew+wi=c) / 可行的左孩子 AddLiveNode(E,Ew+wi+ri,1,i+1); if (bestwEw+wi) bestw=

8、Ew+wi; if(bestw0;j-) bestxj = E-LChild; E = E-parent; return Ew; AddLiveNode(float wt, int lev,bbnode *E, int ch) bbnode *b=new bbnode; b-parent=E; b-LChild=ch; HeapNode N; N.uweight=wt; N.level=lev; N.ptr=b; Insert(H,N) ; 3.3 测试结果与分析图3.2 货物装载问题的解由图可以看出,当输入货箱的个数为5时,第一艘船的载重量为50,第二艘船的载重量为70时,每个货箱的质量分别

9、是12,14,16,20,20,得到如下图的结果。第四章 基于队列式(FIFO)分支限界法解决货物装载问题4.1 算法设计将此问题转化为一艘船的最优化问题,问题的解空间为一个子集树。也就是算法要考虑的所有物品的取、舍情况的组合,n个物品的取舍组合共2的N次个分支,搜索子集树是NP-复杂问题。如下图所示,xi为1表示选取第i件物品,xi 为0表示不选取第i件物品。搜索结点3,时 可以确定它不必被扩充为活结点;因为扩展结点1后,就知道最大装载量不会小于50;而扩展节点3时,发现此分支的“装载上界”为w2+w3=2050,无需搜索此分支,节点3不必入队。图 4-1 子集图4.2 数据结构设计用FIFO分支搜索所有的分支,并记录已搜索分支的最优解,搜索完子集树也就找到出了问题的解。要想求出最优解,必须搜素出最优解,必须搜索到叶节点。所以要记录树的层次,当层次为n+1时,搜索完全部叶节点

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1