下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、精选优质文档-倾情为你奉上实验五:贪心算法求解背包问题实验内容应用贪心算法求解离散背包问题,分析时间复杂度。有一个承重为W的背包和n个物品,它们各自的重量和价值分别是wi和vi(1<=i<=n),设 求这些物品中最有价值的一个子集。如果每次选择某一个物品的时候,只能全部拿走,则这一问题称为离散(0-1)背包问题;如果每次可以拿走某一物品的任意一部分,则这一问题称为连续背包问题。 算法思想 动态规划的思想: 对较小的子问题进行一次求解,并把结果记录下来,然后利用较小问题的解,求解出较大问题的解,直到求解出最大问题的解。引进一个二维数组chMAXMAX,用chij记录CH1与CH2的L
2、CS 的长度,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<=ch2Len;j+)if(CH1i-1=CH2j-1)/相等字符chij=chi
3、-1j-1+1;bij=0;else if(chi-1j>=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);/左上cout<<xi-1<<" " else if(bij = 1) printCS(b, x,
4、i-1, j);/上 else printCS(b, x, i, j-1);/左源程序/应用贪心算法求解离散背包问题#include<iostream>using 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(
5、Elem);L.length=0;L.listsize=100;/*/构造背包,顺序表/*void input(SqList &L)cout<<"请输入物品的个数:"cin>>L.length;for(int i=0;i<L.length;i+)cout<<"请输入第"<<i+1<<"个物品的重量和价值:"cin>>L.elemi.W>>L.elemi.V;L.elemi.P=L.elemi.V/L.elemi.W;cout<<
6、;"价值比为:"<<L.elemi.P<<endl;L.elemi.number=i+1;/*/插入排序由大到小/*void inser(SqList &L) Elem inserter;int index;/inserter待插入合适位置的元素,index指示插入位置 for(int pass=1;pass<L.length;pass+) /共比较size-1轮inserter=L.elempass;/第pass轮时,待插入的对象是apassindex=pass-1;while(index>=0&&inserte
7、r.P>L.elemindex.P) /寻找插入位置L.elemindex+1=L.elemindex;index-;/指针前移,再比较L.elemindex+1=inserter;/跳出while时,找到插入位置/end of forcout<<"按照价值比由大到小排列的顺序为:"for(pass=0;pass<L.length;pass+)cout<<L.elempass.number<<" "cout<<endl;/*8/背包程序/采用贪心算法/根据价值和重量的比来实现贪心算法/*void
8、 bag(SqList L)double w,sumV=0,sumW=0;int listMAX,a=0;cout<<"请输入背包承重量W:"cin>>w;inser(L);for(int i=0;i<L.length;i+)while(sumW+L.elemi.W<=w)sumW=sumW+L.elemi.W;sumV=sumV+L.elemi.V;lista+=L.elemi.number;cout<<"最后包里的总重量为:"<<sumW<<endl;cout<<"最后包里的总价值为:"<<sumV<<endl;cout<<"放到背包中的物品的序号列表为:"for(i=0;i<a;i+)cout<<listi<<" "int main()cout<<"贪心算法求解背包问题"<<endl;SqList L; InitList_Sq(L);input(L);bag(L);return 0;实验结论1、 运行截图查找最长公共子序列长度时
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2026年医疗投诉处理标准化沟通流程
- 淋浴花洒更换安装服务协议
- 极端天气下血液应急调配信息化平台构建
- 海南省琼海市2025-2026学年七年级下学期教学质量监测道德与法治试卷(无答案)
- 医学26年:扩张型心肌病管理 心内科查房
- 26年胰腺癌精准医疗循证证据解读
- 医学26年:泌乳素结果解读要点 查房课件
- 高中2025阅读改变人生主题班会说课稿
- 26年长期生存第二癌监测
- 26年基因检测临床研究设计指南
- 【新课标】水平四(七年级)体育《田径:快速起动加速跑》教学设计及教案(附大单元教学计划18课时)
- 电力交易员基础知识培训课件
- 机械补贴协议书
- 火电精益管理办法
- 卡西欧手表5123机芯中文使用说明书
- 小学信息技术课件一等奖
- 实习律师培训结业考试题目及答案
- 蛛网膜下腔出血疑难病例讨论
- 根管治疗技术指南
- GB/T 42231-2022综合客运枢纽通用要求
- DZ/T 0191-19971∶250 000地质图地理底图编绘规范
评论
0/150
提交评论