MFC设计背问题课程设计.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文档。上传文档
查看更多
MFC设计背问题课程设计

课程设计 课程 面向对象程序设计课程设计 题目 背包问题的求解 院系名称 计算机学院 班 级 学生姓名 afan 学 号 组 员 指导教师 时 间 2014.12.01 1 问题要求及任务描述 1.1 题目要求 假设有一个能装入总体积为T的背包和n件体积分别为w1 , w2 , … , wn 的物品,能否从n件物品中挑选若干件恰好装满背包,即使w1 +w2 + … + wn=T,要求找出所有满足上述条件的解。例如:当T=10,各件物品的体积{1,8,4,3,5,2}时,可找到下列4组解: (1,4,3,2) (1,4,5) (8,2) (3,5,2) 1.2 主要任务 可利用回溯法的设计思想来解决背包问题。首先将物品排成一列,然后顺序选取物品装入背包,假设已选取了前i 件物品之后背包还没有装满,则继续选取第i+1件物品,若该件物品太大不能装入,则弃之而继续选取下一件,直至背包装满为止。但如果在剩余的物品中找不到合适的物品以填满背包,则说明刚刚装入背包的那件物品不合适,应将它取出弃之一边,继续再从它之后的物品中选取,如此重复,直至求得满足条件的解,或者无解。 2 解决问题的主要思路和方法 2.1 关键问题 设计对应的算法 弄明白MFC的制作过程 2.2 拟采用解决问题的方法 可利用回溯法的设计思想来解决背包问题。首先将物品排成一列,然后顺序选取物品装入背包,假设已选取了前i 件物品之后背包还没有装满,则继续选取第i+1件物品,若该件物品太大不能装入,则弃之而继续选取下一件,直至背包装满为止。但如果在剩余的物品中找不到合适的物品以填满背包,则说明刚刚装入背包的那件物品不合适,应将它取出弃之一边,继续再从它之后的物品中选取,如此重复,直至求得满足条件的解,或者无解。 2.3 主要算法和处理流程图 算法:动态规划法 开始 开始 开始 开始 输入limitw,n和物品weigh和value 输入limitw,n和物品weigh和value 输入限定重量t,数目n和物品重量w【100】 输入限定重量t,数目n和物品重量w【100】 求出总价值totv; 求出总价值totv; 将输入的物品重量w按从小到大排列 将输入的物品重量w按从小到大排列 Tw=tw+weigh[count1];count1++; Tw=tw+weigh[count1];count1++; NCount1=1;tote=w[count1];Count1++; N Count1=1; tote=w[count1]; Count1++; Twlimitw? Twlimitw? Ntote=tote+w[count2];count2++;= N tote=tote+w[count2];count2++; = Y Y Ytotv删去这个物品value Y totv删去这个物品value Count2=n? Count2=n? Count1n?N是 Count1n? N 是 Tote=t? Tote=t? NY N Y 输出totv和各物品 输出totv和各物品 输出w[] 输出w[] NCount2=n? N Count2=n? 结束 结束 Y结束 Y 结束 3 程序实现 3.1 程序实现时应考虑的问题 变量名的命名 3.2 主要源代码及说明 void CKcsjbyAFDlg::OnSysCommand(UINT nID, LPARAM lParam) { if ((nID 0xFFF0) == IDM_ABOUTBOX) { CAboutDlg dlgAbout; dlgAbout.DoModal(); } else { CDialog::OnSysCommand(nID, lParam); } } // If you add a minimize button to your dialog, you will need the code below // to draw the icon. For MFC applications using the document/view model, // this is automatically done for you by the framework. void CKcsjbyAFDlg::OnPaint()

文档评论(0)

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

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

1亿VIP精品文档

相关文档