




全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
实验五:贪心算法求解背包问题实验内容应用贪心算法求解离散背包问题,分析时间复杂度。有一个承重为W的背包和n个物品,它们各自的重量和价值分别是wi和vi(1=i=n),设 求这些物品中最有价值的一个子集。如果每次选择某一个物品的时候,只能全部拿走,则这一问题称为离散(0-1)背包问题;如果每次可以拿走某一物品的任意一部分,则这一问题称为连续背包问题。 算法思想 动态规划的思想: 对较小的子问题进行一次求解,并把结果记录下来,然后利用较小问题的解,求解出较大问题的解,直到求解出最大问题的解。引进一个二维数组chMAXMAX,用chij记录CH1与CH2的LCS 的长度,bij记录chij是通过哪一个子问题的值求得的,以决定搜索的方向。我们是自底向上进行递推计算,那么在计算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 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;double 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.elemi.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按照价值比由大到小排列的顺序为:;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至2030年中国流平仪行业市场深度分析及投资潜力预测报告
- 2025版白酒产品售后服务合作协议
- 2025版发动机大修与动力性能再生产服务合同
- 二零二五版城市景观绿化工程招投标合同及养护协议
- 二零二五年度姜云离婚协议书:财产分割与子女教育
- 二零二五年度家具租赁合同与服务协议
- 数学人教A版(2019)选择性必修第一册2.5.1 直线与圆的位置关系 教案
- 精选芭蕾舞男女演员之间的潜规则汇总
- 慢阻肺随访记录表格模板
- SF∕T 0124-2021 录像过程分析技术规范
- 四讲业主业主大会业主委员会PPT课件
- 永磁涡流传动器的应用示范及产业化20150706
- EPC项目—承包人建议书、承包人实施计划
- 被执行人财产申报表
- 赫章县地质灾害防治规划
- 复合活性羟基磷灰石陶瓷的研制及其生物相容性研究
- 《放射物理与防护》第四章
评论
0/150
提交评论