背包问题动态规划和贪心法实现.docx

背包问题动态规划和贪心法实现.docx

ID:57458498

大小:94.34 KB

页数:14页

时间:2020-08-22

背包问题动态规划和贪心法实现.docx_第1页
背包问题动态规划和贪心法实现.docx_第2页
背包问题动态规划和贪心法实现.docx_第3页
背包问题动态规划和贪心法实现.docx_第4页
背包问题动态规划和贪心法实现.docx_第5页
资源描述:

《背包问题动态规划和贪心法实现.docx》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、-背包问题(动态规划和贪心法实现)————————————————————————————————作者:————————————————————————————————日期:算法设计与分析实验报告实验二0-1背包问题院系:班级:计算机科学与技术学号:姓名:任课教师:成绩:湘潭大学2016年5月实验二0-1背包问题一.实验内容分别编程实现动态规划算法和贪心法求0-1背包问题的最优解,分析比较两种算法的时间复杂度并验证分析结果。二.实验目的1、掌握动态规划算法和贪心法解决问题的一般步骤,学会使用动态规划和贪心法解决实际问题;2、理解动态规划算法和贪心法的异同及各自的适用范围。三.算法描述/*动

2、态规划0-1背包问题算法如下*/TemplateVoidKnapsack(Typev,intw,intc,intn,Type**m){ intjMax=min(w[n]-1,c);For(intj=0;j<=jMax;j++){ m[n][j]=0;}For(intj=w[n];j<=c;j++){ m[n][j]=v[n];}For(inti=n-1;i>1;i--){ jMax=min(w[i]-1,c);For(intj=0;j<=jMax;j++)m[i][j]=m[i+1][j];For(intj=w[i];j<=c;j++)min[i][j]=max(m[

3、i+1][j],m[i+1][j-w[i]]+v[i]);}m[1][c]=m[2][c];If(c>=w[1])m[1][c]=max(m[1][c],m[2][c-w[1]]+v[1]);}TemplateVoidTraceback(Type**m,intw,intc,intn,intx){ for(inti=1;i

4、算法Traceback计算如下。如果m[1][c]=m[2][c],则x1=0,否则x1=1。当x1=0时,由m[2][c]继续构造最优解。当x1=1时,由m[2][c-w1]继续构造最优解。以此类推,可构造出相应的最优解(x1,x2,...,xn),时间复杂性O(n2^n)。/*贪心法0-1背包问题*/首先计算每种物品单位重量的价值Vi/Wi,然后,依贪心选择策略,将尽可能多的单位重量价值最高的物品装入背包。若将这种物品全部装入背包后,背包内的物品总重量未超过C,则选择单位重量价值次高的物品并尽可能多地装入背包。依此策略一直地进行下去,直到背包装满为止。四.算法实现1.数据结构及函数说明

5、在该问题中物品质量W[n]和包所能承受的最大重量都是又用户自己任意定义的,在实现的过程中用到一个栈来实现。第i件物品的选择有两种可能:                             i.              物品i被选择,这种可能性仅当包含它不会超过方案总重量的限制时才是可行的。选中后。继续其余物品的选择;                            ii.              物品i不被选择,这种可能性仅当不包含物品i不满足条件的情况。 现以第一个物品为例,当物品1不被选择,则问题转变为相对于其他物品(2,3,……,n),背包重量仍然为maxweight;

6、若物品1被选择,问题就变为关于最大背包重量为maxweight-w[1]的问题,现设r{maxweight, maxweight-w[1]}为剩余重量的背包问题。1.源程序代码/*动态规划0-1背包问题*/#include#includeintV[200][200];intmax(inta,intb){if(a>=b)returna;elsereturnb;}intKnapSack(intn,intw[],intv[],intx[],intC){inti,j;for(i=0;i<=n;i++)V[i][0]=0;for(j=0;j<=C;j++)V[0][

7、j]=0;for(i=0;i<=n-1;i++)for(j=0;j<=C;j++)if(j=0;i--){if(V[i][j]>V[i-1][j]){x[i]=1;j=j-w[i];}elsex[i]=0;}printf("选中的物品是:")

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。