与利润有关的背包问题.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
与利润有关的背包问题

大学 学院 计算机程序训练任务书 学生姓名: 班级: 学号: 设计题目 :《与利润有关的背包问题》 一,题目: 《与利润有关的背包问题》 二,问题描述: 输入N种货物重量w kg及获利p,输出各种货物及重量到文件。 题目解释:一个商人带着一个能装m kg的背包去乡下收购货物,准备将这些货物卖到城里获利。现有n种货源,且知第i种货物有wi kg,可获利pi元。请编写算法帮助商人收购货物,以获取最高的利润。 三,系统设计说明: 系统用到的数据类型程序设计一般由两部分组成:算法和数据结构,合理地选择和实现一个数据结构和处理这些数据结构具有同样的重要性#includestdio.h #define N 30 typedef struct { int bh; float m; float h; float l; 2、main()主函数 程序采用函数调用的设计理念,主函数程序的入口,各调用函数均由主函数控制调用。控制功能的实现通过循环执行一个开关语句,该语句的条件值是通过调用主菜单得到的返回值(head),根据该值,调用相应的各功能函数。 3.printf()输出函数 直接利用输出函数printf输出字符串,在屏幕上显示一个菜单。 四,功能 本程序功能是输入N种货物重量w kg及获利p,输出各种货物及重量到文件,通过C语言程序最终帮助商人获取最大利润 1.N-S图: 2.功能流程图如下: (1)将C程序在C++中运行初始界面如下: (2)依次按要求输入每种货物的质量m和所获得得利润h,和背包的最大载重x如下: (3)最后输出结果如下: 五,程序思路: 定义货物种类数最大限度为30种。 定义结构体struct,并说明结构体可以用字母B代替,结构体中定义所需的变量类型。 主函数中结构体B b[N]定义各变量。 以整型数据输入物品的种类,并在屏幕上自动显示出来,用一个for循环来控制程序中物品的种类数。 输入每种货物的质量和所获利润,并计算他们的比,即h|m 输入背包的最大载重,并利用for循环使货物的最大质量不能超过背包的最大载重。 7. if(b[j].lb[i].l) { cent=b[i]; b[i]=b[j]; b[j]=cent; 使b[i]和b[j]的值互换以达到l降序排列的目的。 8. if((x-=b[n].m)0) break; 使选择货物的质量不能超过背包的质量。 9.最后利用语句y+=b[i].h;使利润进行累加,最终输出最大利润。 六,源程序 #includestdio.h #define N 30 typedef struct { int bh; int m; int h; float l; } B; main() { B b[N],cent; int i,a,j,n; int x,y=0; printf(要输入货物的种类数:\n); scanf(%d,a); for(i=0;ia;i++) { b[i].bh=i+1; printf(请输入第%d种货物的质量m: ,b[i].bh); scanf(%d,b[i].m); printf(请输入第%d种货物获利h: ,b[i].bh); scanf(%d,b[i].h); b[i].l=b[i].h/b[i].m; } printf(输入背包最大载重x: ); scanf(%d,x); for(i=0;ia-1;i++) for(j=i+1;ja;j++) if(b[j].lb[i].l) { cent=b[i]; b[i]=b[j]; b[j]=cent; } for(n=0;;n++) if((x-=b[n].m)0) break; printf(收购第:); for(i=0;in;i++) { printf(%3d,b[i].bh); y+=b[i].h; } printf(种货物可获最高利润:%d\n,y); } 七,参考文献 《c程序设计(第三版)》 谭浩强编 清华大学出版社2006年 《算法设计与分析》 吕国英 清华大学出版社2003年 八,结束语 通过这次《程序设计》课程的一次全面的综合性上机实验 定义宏替换#define N 30 定义一个结构体变量B,组成成员分别有bh,m,h,l, 输入信息数组m的值 for(i=0;im;i++ b[i].bh=i+1 输入第n个质量 m 即b[i].m 输入第n个获利h 即b[i].h b[i].l=b[i].h|b[i].m

文档评论(0)

cgtk187 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档