- 1、本文档共21页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 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)