




下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、实验五:贪心算法求解背包问题实验内容应用贪心算法求解离散背包问题,分析时间复杂度。有一个承重为w的背包和n个物品,它们各自的重量和价值分别是wi和vi(1=i=n),设 求这些物品中最有价值的一个子集。如果每次选择某一个物品的时候,只能全部拿走,则这一问题称为离散(0-1)背包问题;如果每次可以拿走某一物品的任意一部分,则这一问题称为连续背包问题。 算法思想 动态规划的思想: 对较小的子问题进行一次求解,并把结果记录下来,然后利用较小问题的解,求解出较大问题的解,直到求解出最大问题的解。引进一个二维数组chmaxmax,用chij记录ch1与ch2的lcs 的长度,bij记录chij是通过哪一
2、个子问题的值求得的,以决定搜索的方向。我们是自底向上进行递推计算,那么在计算chi,j之前,chi-1j-1,chi-1j与chij-1均已计算出来。此时我们根据ch1 i = ch2j还是ch1i != ch2j,就可以计算出chij。算法length(string ch1,string ch2,int bmaxmax)/用于构建动态数组/输入:两字符窜/输出:最长公共子序列for(i=1;i=ch1len;i+)/二重循环求解for(int j=1;j=chij-1)/上比较大chij=chi-1j;bij=1;else/左比较大chij=chij-1;bij=-1;printcs(int
3、 bmaxmax,string x,int i,int j)/回溯求出最长子序列输出/输入:标记数组/输出:最长子序列if(i = 0 | j = 0)/边界,返回return; if(bij = 0) printcs(b, x, i-1, j-1);/左上coutxi-1 ; else if(bij = 1) printcs(b, x, i-1, j);/上 else printcs(b, x, i, j-1);/左源程序/应用贪心算法求解离散背包问题#includeusing namespace std;#define max 100/结构体struct elem double w;dou
4、ble v;double p;int number;/顺序表struct sqlist elem *elem;int length;int listsize;/构造一个空的线性顺序表void initlist_sq(sqlist &l)l.elem=(elem *)malloc(100*sizeof(elem);l.length=0;l.listsize=100;/*/构造背包,顺序表/*void input(sqlist &l)coutl.length;for(int i=0;il.length;i+)cout请输入第i+1l.elemi.wl.elemi.v;l.elemi.p=l.ele
5、mi.v/l.elemi.w;cout价值比为:l.elemi.pendl;l.elemi.number=i+1;/*/插入排序由大到小/*void inser(sqlist &l) elem inserter;int index;/inserter待插入合适位置的元素,index指示插入位置 for(int pass=1;pass=0&inserter.pl.elemindex.p) /寻找插入位置l.elemindex+1=l.elemindex;index-;/指针前移,再比较l.elemindex+1=inserter;/跳出while时,找到插入位置/end of forcout按照
6、价值比由大到小排列的顺序为:;for(pass=0;passl.length;pass+)coutl.elempass.number ;coutendl;/*8/背包程序/采用贪心算法/根据价值和重量的比来实现贪心算法/*void bag(sqlist l)double w,sumv=0,sumw=0;int listmax,a=0;coutw;inser(l);for(int i=0;il.length;i+)while(sumw+l.elemi.w=w)sumw=sumw+l.elemi.w;sumv=sumv+l.elemi.v;lista+=l.elemi.number;cout最后包里的总重量为:sumwendl;cout最后包里的总价值为:sumvendl;cout放到背包中的物品的序号列表为:;for(i=0;ia;i+)coutlisti ;int main()cout贪心算法求解背包问题endl;sqlist l; initlist_sq(l);input(l);bag(l);return 0;实验结论1、 运行截图查找最长公共子序列长度时的动态规划两个for循环,时间复杂度为()。在回溯查
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年安庆市迎江区事业单位公开招聘工作人员笔试历年典型考题及考点剖析附带答案详解
- 怎样下载数学教学课件
- 点亮新学期开启新征程-2025年秋季高一开学第一课主题班会课件-2025-2026学年高中主题班会
- 第十章化工机泵第五节风机37课件
- 第三章防火防爆技术23课件
- 地铁检修教学课件
- 2025年二级注册建筑师考试真题及答案
- 口腔基础知识课件下载
- 小学生秋冬季节疾病课件
- 2025年音乐版权运营与流媒体平台付费模式协同发展研究报告
- 公路应急值守管理办法
- 财务离职保密协议及竞业限制合同范本
- 市政工程施工员考试试题及答案
- 2025年陕西行政执法资格考试备考模拟题及答案(题型)
- 实验室培育钻石行业技术发展趋势报告
- 2025年领英大制造行业人才全球化报告-马来西亚篇
- 心肺复苏双人培训
- 2025年高考化学试卷(广东卷)(空白卷)
- 2025年北京市高考英语试卷真题(含答案解析)
- 国际压力性损伤-溃疡预防和治疗临床指南(2025年版)解读课件
- 压力管道安装质量的证明书
评论
0/150
提交评论