- 1、本文档共5页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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
您可能关注的文档
- 《老古玩店》小耐儿的悲惨命运-精选文档.doc
- 《老年护理》第7章 老年人的安全用药及护理.doc
- 《老人与海》微课设计.doc
- 《老山界》教案两课时.doc
- 《老山界》语段阅读训练及答案.doc
- 《老师,你在听吗?》读后感-建立平等和谐的师幼对话关系.doc
- 《老师,你在听吗?》读书心得(10).doc
- 《老师. 好》观后感.doc
- 《老鼠嫁女》故事内容.doc
- 《老头子做事总不会错》读后感_550字.doc
- 轻工制造行业2025年度策略:把握政策受益方向,顺应行业发展趋势.pdf
- 能源开采专题:川渝能源市场,及对动力煤格局影响.pdf
- 2025AI行业前瞻报告:Al行业关键时刻:瓶颈与机遇并存必威体育精装版完整版本.pdf
- 新能源行业-风电24Q3总结:Q3下游交付陆续起量,风机毛利率环比改善.pdf
- 内容创造新势力:MCN模式解析与数字营销创新路径-头豹词条报告系列.pdf
- 考研题库 《测量学》(第4版)配套题库(课后习题+章节题库(真题)+模拟试题).docx
- Unit 2 听说课-分层作业 (解析版).docx
- 精品课件:2.3_相反数.ppt
- 《一元一次方程》参考课件.ppt
- 【完形填空】2022届高考英语专项突破 完型填空变式模拟题(二).docx
文档评论(0)