回溯法解01背包问题.ppt

  1. 1、本文档共21页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
回溯法解决01背包问题 回溯法解决01背包问题 1、算法思想 2、问题描述 3、设计实现 回溯法解决01背包问题 回溯法:是一个既带有系统性又带有跳跃性的的 搜索算法。它在包含问题的所有解的解空间树中,按照 深度优先的策略,从根结点出发搜索解空间树。算法搜 索至解空间树的任一结点时,总是先判断该结点是否肯 定不包含问题的解。如果肯定不包含,则跳过对以该结 点为根的子树的系统搜索,逐层向其原先结点回溯。否 则,进入该子树,继续按深度优先的策略进行搜索 课堂上老师已经讲解过用回溯法解决n-皇后问题, m-图着色问题以及哈密顿环问题,他们有相同的特征 即问题的求解目标都是求满足约束条件的全部可行解 而0/背包是最优化问题,还需要使用限界函数剪去已 能确认不含最优答案结点的子树。 回溯法解决0/1背包问题 ●运用回溯法解题通常包含以下三个步骤: a.针对所给问题,定义问题的解空间; b.确定易于搜索的解空间结构; C.以深度优先的方式搜索解空间,并 且在搜索过程中用剪枝函数避免无效搜索; 0/1背包问题概述 在0/1背包问题中,需对容量为c的背包进行装 载。从η个物品中选取装入背包的物品,每件物品 的重量为w价值为p对于可行的背包装载,背包 中的物品的总重量不能超过背包的容量,最佳装载 是指所装入的物品价值最高,即∑P取得最大值。 约束条件为wc和x∈pl≤si≤n)2 在这个表达式中,需求出x的值。X1=1表示物 品i装入背包中,X=0表示物品不装入背包 回溯法解决01背包问题 ●01背包形式化描述 ●给定M0,w20,p20(0≤n),要求一个n 元组(x0,x1,…,xn-=1),x1∈{0,1}, 0≤icn,使得∑0W2x1≤M且0×nP2x 最大。(xX=1表示物品i装入背包中,X=0表 示物品不装入背包) 回溯法解决01背包问题 ●判定可行解的约束条件是: ●∑=0Wx1≤M,Wz0,x2=0或者1 (0n) ●目标函数取最大值: ●max∑=p2x,p20,x1=0或1(0≤n) 问题举例最优值上界 对于0-1背包问题回溯法的一个实例,n=4, M=7,p=[9,10,7,4]W=[3,52,1这4个物品的单 位重量价值分别为[323,54]以物品为单位价值 的递减序装入物品。先装入物品4,然后装入物 3和1.装入这3个物品后,剩余的背包容量为1, 只能装入02个物品2由此可得到一个解为 X=[1,02,1,],其相应的价值为22尽管这不是 个可行解,但可以证明其价值是最有大的上界 因此,对于这个实例,最优值不超过22 回溯法解决01背包问题 ●01背包问题是一个子集选取问题,适合 于用子集树表示0—1背包问题的解空间。 在搜索解空间树是,只要其左儿子节点是 个可行结点,搜索就进入左子树,在右 子树中有可能包含最优解是才进入右子树 搜索。否则将右子树剪去。 问题分析: 首先是将可供选择的物品的个数输入程序,将物品排成一列,计 算总物品的体积s,然后输入背包的实际体积V,如果背包的体积 小于0或者大于物品的总体积s,则判断输入的背包体积错误,否 则开始顺序选取物品装入背包,假设已选取了前i件物品之后背包 还没有装满,则继续选取第+1件物品,若该件物品太大”不能装 入,则弃之而继续选取下一件,直至背包装满为止。但如果在剩 余的物品中找不到合适的物品以填满背包,则说明刚刚装入背包 的那件物品不合适”,应将它取出弃之一边,继续再从它之后 的物品中选取,如此重复,直至求得满足条件的解。 因为回溯求解的规则是后进先出,所以要用到栈来存储符合条件 的解,在存储过程中,利用数组来存储各个物品的体积,然后用 深度优先的搜索方式求解,将符合条件的数组元素的下标存入栈 里,最后得到符合条件的解并且实现输出。

文档评论(0)

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

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

1亿VIP精品文档

相关文档