01背包(动态规划).docVIP

  1. 1、本文档共5页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
算法分析与设计实验报告 第 3 次实验 姓名 学号 班级 时间 11.14下午 地点 四合院 实验名称 动态规划法求解背包问题 实验目的 通过上机实验,要求掌握动态规划算法的问题描述、算法设计思想、程序设计。 利用动态规划算法求解背包问题,并计算出程序运行所需要的时间。 实验原理 给定几组数据,利用动态规划算法的思想,把 0-1 背包装满并使得其价值最大。 实验步骤 把问题分解成若干个子问题, 如背包仅可以容纳 1 个物品且可以容纳 的质量为一等。 依次求出各个子问题的最优解。 每个子问题的最优解又可以从它的子问题的最优解中得到。 通过各个子问题的最优解得到原问题的最优解。 关键代码 void KnapSack(int n,int w[],int v[],int x[],int C) { int i,j; int jMax=min(w[n]-1,C); for(j=0;j=jMax;j++) mV[n][j]=0; for(j=w[n];j=C;j++) mV[n][j]=v[n]; for(i=n-1;i1;i--) { jMax=min(w[n]-1,C); for(j=0;j=jMax;j++) mV[i][j]=mV[i+1][j]; for(j=w[i];j=C;j++) mV[i][j]=max(mV[i+1][j],mV[i+1][j-w[i]]+v[i]); } mV[1][C]=mV[2][C]; if(C=w[1]) mV[i][j]=max(mV[1][C],mV[2][C-w[1]]+v[1]); } void Traceback(int w[],int C,int n,int x[]){ for(int i=1;in;i++) if(mV[i][C]==mV[i+1][C]) x[i]=0; else { x[i]=1; C-=w[i]; } x[n]=(mV[n][C])?1:0; } 测试结果 实验心得 通过这次实验,我回顾了动态算法求解背包问题,在其中加入了舍伍德随机化取值过程,使数据分布更加均匀,让我熟悉了随机化算法,也让结果更加公平可靠。 本次实验在书本有详细的算法,但是刚开始的时候难以理解其精髓,后来通过和同学讨论才知道该算法与一般的做法有点不同,是从最后一个物品进行考虑的,这样方便了子问题的划分和代码的实现。这次实验让我知道,有时候不能墨守陈规,编写代码应该要打开自己的思路,从多方面进行考虑,才能写出最简单,方便的算法。 实验得分 助教签名 附录:完整代码 #includestdio.h #includestdlib.h #includetime.h int mV[200][200]; //前i个物品装入容量为j的背包中获得的最大价值 int max(int a,int b) { if(a=b) return a; else return b; } int min(int a,int b) { if(ab) return a; else return b; } void KnapSack(int n,int w[],int v[],int x[],int C) { int i,j; int jMax=min(w[n]-1,C); for(j=0;j=jMax;j++) mV[n][j]=0; for(j=w[n];j=C;j++) mV[n][j]=v[n]; for(i=n-1;i1;i--) { jMax=min(w[n]-1,C); for(j=0;j=jMax;j++) mV[i][j]=mV[i+1][j]; for(j=w[i];j=C;j++) mV[i][j]=max(mV[i+1][j],mV[i+1][j-w[i]]+v[i]); } mV[1][C]=mV[2][C]; if(C=w[1]) mV[i][j]=max(mV

文档评论(0)

我思故我在 + 关注
实名认证
文档贡献者

部分用户下载打不开,可能是因为word版本过低,用wps打开,然后另存为一个新的,就可以用word打开了

1亿VIP精品文档

相关文档