0-1背包问题-贪心法和动态规划法求解.doc

0-1背包问题-贪心法和动态规划法求解.doc

  1. 1、本文档共6页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
0-1背包问题-贪心法和动态规划法求解

实验四 “0-1”背包问题 实验目的与要求 熟悉C/C++语言的集成开发环境; 通过本实验加深对贪心算法、动态规划算法的理解。 实验内容: 掌握贪心算法、动态规划算法的概念和基本思想,分析并掌握“0-1”背包问题的求解方法,并分析其优缺点。 实验题 “0-1”背包问题的贪心算法 “0-1”背包问题的动态规划算法 说明:背包实例采用教材P132习题六的6-1中的描述。要求每种的算法都给出最大收益和最优解。 设有背包问题实例n=7,M=15,,(w0,w1,。。。w6)=(2,3,5,7,1,4,1),物品装入背包的收益为:(p0,p1,。。。,p6)=(10,5,15,7,6,18,3)。求这一实例的最优解和最大收益。 实验步骤 理解算法思想和问题要求; 编程实现题目要求; 上机输入和调试自己所编的程序; 验证分析实验结果; 整理出实验报告。 实验程序 // 贪心法求解 #includeiostream #includeiomanip using namespace std; //按照单位物品收益排序,传入参数单位物品收益,物品收益和物品重量的数组,运用冒泡排序 void AvgBenefitsSort(float *arry_avgp,float *arry_p,float *arry_w ); //获取最优解方法,传入参数为物品收益数组,物品重量数组,最后装载物品最优解的数组和还可以装载物品的重量 float GetBestBenifit(float *arry_p,float *arry_w,float *arry_x,float u); int main(){ float w[7]={2,3,5,7,1,4,1}; //物品重量数组 float p[7]={10,5,15,7,6,18,3}; //物品收益数组 float avgp[7]={0}; //单位毒品的收益数组 float x[7]={0}; //最后装载物品的最优解数组 const float M=15; //背包所能的载重 float ben=0; //最后的收益 AvgBenefitsSort(avgp,p,w); ben=GetBestBenifit(p,w,x,M); coutendlbenendl; //输出最后的收益 system(pause); return 0; } //按照单位物品收益排序,传入参数单位物品收益,物品收益和物品重量的数组,运用冒泡排序 void AvgBenefitsSort(float *arry_avgp,float *arry_p,float *arry_w ) { //求出物品的单位收益 for(int i=0;i7;i++) { arry_avgp[i]=arry_p[i]/arry_w[i]; } coutendl; //把求出的单位收益排序,冒泡排序法 int exchange=7; int bound=0; float temp=0; while(exchange) { bound=exchange; exchange=0; for(int i=0;ibound;i++) { if(arry_avgp[i]arry_avgp[i+1]) { //交换单位收益数组 temp=arry_avgp[i]; arry_avgp[i]=arry_avgp[i+1]; arry_avgp[i+1]=temp; //交换收益数组 temp=arry_p[i]; arry_p[i]=arry_p[i+1]; arry_p[i+1]=temp; //交换重量数组 temp=arry_w[i]; arry_w[i]=arry_w[i+1]; arry_w[i+1]=temp; exchange=i; } } } } //获取最优解方法,传入参数为物品收益数组,物品重量数组,最后装载物品最优解的数组和还可以装载物品的重量 float GetBestBenifit(float *arry_p,float *arry_w,float *arry_x,float u) { int i=0;

文档评论(0)

xcs88858 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

版权声明书
用户编号:8130065136000003

1亿VIP精品文档

相关文档