- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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;// 定义一个指
您可能关注的文档
最近下载
- 成考真题政治题目及答案.docx VIP
- 大家的日语(第二版)(初级)2(第26-50课)习题解答.pdf
- 2025年事业单位工勤技能-甘肃-甘肃电工四级(中级工)历年参考题典型考点含答案解析(5卷版).docx VIP
- 2018寒假托管招生广告.docx VIP
- GB55020-2021《建筑给水排水与节水通用规范》废止的现行工程建设标准相 精品.pdf VIP
- 《油气管道安全管理》课件.ppt VIP
- DB37∕T 3489-2019 山东省农产品质量安全监测抽样技术规范.docx VIP
- 新解读《GB_T 4340.2-2012金属材料 维氏硬度试验 第2部分:硬度计的检验与校准》.docx VIP
- GB/T 12706.3-2020 额定电压1kV(Um1.2 kV)到35kV(Um40.5 kV)挤包绝缘电力电缆及附件 第3部分:额定电压35kV(Um40.5kV)电缆.pdf
- 《主体结构工程检测》PPT课件.pptx VIP
文档评论(0)