欢迎来到三一办公! | 帮助中心 三一办公31ppt.com(应用文档模板下载平台)
三一办公
全部分类
  • 办公文档>
  • PPT模板>
  • 建筑/施工/环境>
  • 毕业设计>
  • 工程图纸>
  • 教育教学>
  • 素材源码>
  • 生活休闲>
  • 临时分类>
  • ImageVerifierCode 换一换
    首页 三一办公 > 资源分类 > PPT文档下载  

    回溯法解决背包问题课件.ppt

    • 资源ID:1571451       资源大小:2.02MB        全文页数:23页
    • 资源格式: PPT        下载积分:16金币
    快捷下载 游客一键下载
    会员登录下载
    三方登录下载: 微信开放平台登录 QQ登录  
    下载资源需要16金币
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    回溯法解决背包问题课件.ppt

    回溯法解决01背包问题,回溯法解决01背包问题,1、算法思想2、问题描述3、设计实现,回溯法解决01背包问题,回溯法:是一个既带有系统性又带有跳跃性的的搜索算法。它在包含问题的所有解的解空间树中,按照深度优先的策略,从根结点出发搜索解空间树。算法搜索至解空间树的任一结点时,总是先判断该结点是否肯定不包含问题的解。如果肯定不包含,则跳过对以该结点为根的子树的系统搜索,逐层向其原先结点回溯。否则,进入该子树,继续按深度优先的策略进行搜索。 课堂上老师已经讲解过用回溯法解决n-皇后问题,m-图着色问题以及哈密顿环问题,他们有相同的特征即问题的求解目标都是求满足约束条件的全部可行解。而0/1背包是最优化问题,还需要使用限界函数剪去已能确认不含最优答案结点的子树。,回溯法解决0/1背包问题,运用回溯法解题通常包含以下三个步骤: a. 针对所给问题,定义问题的解空间; b. 确定易于搜索的解空间结构; c. 以深度优先的方式搜索解空间,并且在搜索过程中用剪枝函数避免无效搜索;,0/1背包问题概述,在0/1背包问题中,需对容量为c的背包进行装载。从n个物品中选取装入背包的物品,每件物品 i的重量为wi, 价值为pi。对于可行的背包装载,背包中的物品的总重量不能超过背包的容量,最佳装载是指所装入的物品价值最高,即 取得最大值。约束条件为 c和 。 在这个表达式中,需求出xi的值。xi=1表示物品i装入背包中,xi=0表示物品i不装入背包。,回溯法解决01背包问题,回溯法解决01背包问题,问题举例最优值上界,对于0-1背包问题回溯法的一个实例,n=4,M=7,p=9,10,7,4,w=3,5,2,1.这4个物品的单位重量价值分别为3,2,3,5,4.以物品为单位价值的递减序装入物品。先装入物品4,然后装入物品3和1.装入这3个物品后,剩余的背包容量为1,只能装入0.2个物品2.由此可得到一个解为x=1,0.2,1,1,其相应的价值为22.尽管这不是一个可行解,但可以证明其价值是最有大的上界。因此,对于这个实例,最优值不超过22.,回溯法解决01背包问题,01背包问题是一个子集选取问题,适合于用子集树表示01背包问题的解空间。在搜索解空间树是,只要其左儿子节点是一个可行结点,搜索就进入左子树,在右子树中有可能包含最优解是才进入右子树搜索。否则将右子树剪去。,问题分析:,首先是将可供选择的物品的个数输入程序,将物品排成一列,计算总物品的体积s,然后输入背包的实际体积V,如果背包的体积小于0或者大于物品的总体积s,则判断输入的背包体积错误,否则开始顺序选取物品装入背包,假设已选取了前i 件物品之后背包还没有装满,则继续选取第i+1件物品,若该件物品太大不能装入,则弃之而继续选取下一件,直至背包装满为止。但如果在剩余的物品中找不到合适的物品以填满背包,则说明刚刚装入背包的那件物品不合适,应将它取出弃之一边,继续再从它之后的物品中选取,如此重复,直至求得满足条件的解。因为回溯求解的规则是后进先出,所以要用到栈来存储符合条件的解,在存储过程中,利用数组来存储各个物品的体积,然后用深度优先的搜索方式求解,将符合条件的数组元素的下标存入栈里,最后得到符合条件的解并且实现输出。,限界函数,设r是当前剩余物品价值总和;cp是当前结点X的价值;bp是当前X结点上界函数值。 L始终为已搜索到的答案节点中受益的最大值,当cp+r=bpL时可剪去以X为根的子树。计算右子树中解的上界的更好方法是将剩余物品依其单位重量价值排序,然后依次装入物品,直至装不下时,再装入该物品的一部分而装满背包。由此得到的价值是右子树中解的上界。,2022/12/7,12,可编辑,L始终为已搜索到的答案节点中受益的最大值,最优解必定大于等于L,对于任意结点X,若其上界函数值bpL,则可以断定X子树上不含最优答案结点,可以剪去以X为根的子树,Z,Y,X,T,bp=cp+r,rp,cw,cp,考察如下背包问题:n=3,w=11,8,6,p=18,25,20且M=20.,三个对象的背包问题的解空间 1 0 1 0 1 0 0 0 1 0 1 0 1 0,A,B,G,I,F,H,E,L,D,C,L=43,L=43,L=38,L=25,L=20,L=0,L=45,L=18,回溯法解决0/1背包问题,#includeint c; /背包容量 int n; /物品数 int weight100; /存放n个物品重量的数组 int price100; /存放n个物品价值的数组 int currentWeight=0; /当前重量 int currentPrice=0; /当前价值 int bestPrice=0; /当前最优值 int bestAnswer100; /当前最优解 int bp=0;int bA100; /当前最优解 int times=0;,回溯法解决01背包问题,void Print(); void Backtracking(int i) times+=1;if(in) Print();if(bestPricebp)bp=bestPrice;for(int j=1;j=n;j+) bAj=bestAnswerj;return; ,回溯法解决01背包问题,if(currentWeight+weighti=c) /将物品i放入背包,搜索左子树 bestAnsweri = 1; currentWeight += weighti; bestPrice += pricei; Backtracking(i+1); /完成上面的递归,返回到上一结点,物品i不放入背包,准备递归右子树 currentWeight -= weighti; bestPrice -= pricei; bestAnsweri = 0; Backtracking(i+1); ,回溯法解决01背包问题,void Print() int i; printf(n路径为 ); for(i=1;in;+i) printf(%d,bestAnsweri); printf(%dt价值为%dn,bestAnsweri,bestPrice); void main() int i; /*输入部分*/ printf(请输入物品的数量:n); scanf(%d,回溯法解决01背包问题,for(i=1;i=n;i+) scanf(%d, ,回溯法解决01背包问题,回溯法解决01背包问题,回溯法解决01背包问题,THANK YOU !,2022/12/7,23,可编辑,

    注意事项

    本文(回溯法解决背包问题课件.ppt)为本站会员(牧羊曲112)主动上传,三一办公仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知三一办公(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    备案号:宁ICP备20000045号-2

    经营许可证:宁B2-20210002

    宁公网安备 64010402000987号

    三一办公
    收起
    展开