算法分析与设计贪心算法.docxVIP

  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文档。上传文档
查看更多
专业课程实验报告 课程名称: 课程名称: 算法分析与设计 开课学期: 2014 至 2015 学年第1 学期 专业: 软件工程 年级班级:2012级03班 学生姓名: 学生姓名: 李明洋 学号:222012321062053 曹严元实验教师: 曹严元 计算机与信息科学学院软件学院 实验项目名称贪心算法 实验项目名称 贪心算法 实验时间 2014年门月14 实验类型 □验证性□设计性□综合性 日 「 一、 实验目的 掌握贪心法的基本思想方法; 了解适用于用贪心法求解的问题类型,并能设计相应贪心法算法; 学握贪心算法复杂性分析方法分析问题复杂性。 二、 实验要求 预习实验指导书及教材的有关内容,掌握贪心算法的基本思想; 严格按照实验内容进行实验,培养良好的算法设计和编程的习惯; 认真听讲,服从安排,独立思考并完成实验。 三、实验内容与设计(主要内容,操作步骤、算法描述或程序代码) 实现背包问题的贪心算法 procedure KNAPSACK(P, W, M, X, n) //P(l: n)和W(l; n)分别含有按 P(i)/W(i) P(i+l)/W(i+l)排序的n件物品的效益值 和重So M是背包的容量大小,而x(l: n)是解向量 real P(l: n), W(l: n), X(l: n), M, cu; integer i, n; X-0 //将解向量初始化为零 cu—M //cu是背包剩余容量 for i —1 to n do if W(i)cu then exit endif X(i) T cu*-cu-W(i) repeat if iWn then X(i) —cu/ W(i) endif end GREEDY-KNAPSACK procedure prini(G,) status*- unseen” // T 为空 status[1] “tree node” // 将 1 放入 T for each odge(l, w) do status[w]*- fringe” // 找到 T 的邻接点 dad [w] —1; //w通过1与T建立联系 dist[w] —weight (1, w) //w 到 T 的距离 repeat while status[t]H “tree node do pick a fringe u with min dist W // 选取到 T 最近的节点 status[u]— “tree node” for each edge (u, w) do 修改w和T的关系 repeat repeat 程序代码: #include iostream h struct goodinfo { float p; //物品效益 float w; //物品重量 float X; //物品该放的数量 int flag; //物品编号 };//物品信息结构体 void Insertionsort@oodinfo goods[], int n) { int j, i; for(j=2;j=n;j++) { goods[0]=goods[j]; while (goods[0]. pgoods[i]. p) { goods[i+l]=goods[i]; i—; } goods[i+l]=goods[0]; } }//按物品效益,重量比值做升序排列 void bag(goodinfo goods[], float M, int n) { float cu; int i, j; for(i=l;i=n;i++) goods[i]. X=0; cu=M; //背包剩余容量 for(i=l;in;i++) { if (goods [i]. wcu)//当该物品重量大与剩余容量跳出break; goods[i].X二1; cu二cu-goods [i]. \v; //确定背包新的剩余容量 } if(i=n) goods [i]? X=cu/goods [i]? w; //该物品所要放的量 for(j=2; j=n; j++) goods[0]=goods[j]; i=j-l; while (goods[0]. flaggoods[i]. flag) { goods[i+1]二goods[i]; i—; } goods[i+l]=goods[0]; } cout?/z最优解为:,,endl; for(i=l;i=n;i++) { coutC第〃《i〃件物品要放:〃; coutgoods[ij.Xendl; } } void main() { cout〃 | 运用贪心法解背包问题 |/z?endl; cout| 1,z?endl: int j; int n; float M; goodinfo * goods;// 定义一个指

文档评论(0)

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

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

1亿VIP精品文档

相关文档