欢迎来到课桌文档! | 帮助中心 课桌文档-建筑工程资料库
课桌文档
全部分类
  • 党建之窗>
  • 感悟体会>
  • 百家争鸣>
  • 教育整顿>
  • 文笔提升>
  • 热门分类>
  • 计划总结>
  • 致辞演讲>
  • 在线阅读>
  • ImageVerifierCode 换一换
    首页 课桌文档 > 资源分类 > DOCX文档下载  

    算法设计与分析实验报告背包问题.docx

    • 资源ID:17751       资源大小:72.48KB        全文页数:5页
    • 资源格式: DOCX        下载积分:10金币
    快捷下载 游客一键下载
    会员登录下载
    三方登录下载: 微信开放平台登录 QQ登录  
    下载资源需要10金币
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    算法设计与分析实验报告背包问题.docx

    问题描述给定n种物品和一个背包。物品i的重量是,其价值为,背包容量为C。问应该如何选择装入背包的物品,使得装入背包中物品的总价值最大?问题分析0/1背包问题的可形式化描述为:给定C>0,>0,>0,要求找出n元0/1向量,使得,而且达到最大。因此0/1背包问题是一个特殊的整数规划问题。算法设计设0/1背包问题的最优值为m<i,j>,即背包容量是j,可选择物品为i,i+1,n时0/1背包问题的最优值。由0/1背包问题的最优子结构性质,可以建立计算m<i,j>的递归式如下:maxm<i+1,j>,m<i+1,j->+ m<i,j>=m<i+1,j>m<n,j>=0 算法实现#include <iostream.h>#include<string.h> #include<iomanip.h> int min<int w, int c> int temp; if <w < c>temp = w; else temp = c; return temp; Int max<int w, int c> int temp; if <w > c>temp = w; else temp = c; return temp; void knapsack<int v, int w, int* m, int c, int n>/求最优值 int jmax = min<wn-1, c> for <int j = 0; j <= jmax; j+> mnj = 0; for <int jj = wn; jj <= c; jj+> mnjj = vn; for<int i = n-1; i > 1; i->/递归部分 jmax = min<wi-1, c> for<int j = 0; j <= jmax; j+> mij = mi+1j; for<int jj = wi; jj <= c; jj+> mijj = max<mi+1jj, mi+1jj-wi+vi> m1c = m2c; if<c >= w1> m1c = max<m1c, m2c-w1+v1> cout << endl << "最优值:" << m1c << endl; cout<<endl; cout<< "&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&" << endl; int traceback<int x, int w, int* m, int c, int n> /回代,求最优解 out << endl << "得到的一组最优解如下: " << endl; for<int i = 1; i < n; i+> if<mic = mi+1c>xi = 0; else xi = 1; c -= wi; xn = <mnc> ? 1:0; for<int y = 1; y <= n; y+> cout << xy << "t" cout << endl;return xn; void main<> int n, c; int *m; cout << "&&&&&&&&&&&&&&&&&&&&&欢迎使用0-1背包问题程序&&&&&&&&&&&&&&&&&&&" << endl; cout << "请输入物品个数:" cin >> n ; cout << endl << "请输入背包的承重:"cin >> c;int *v = new intn+1; cout << endl << "请输入每个物品的价值 <vi>:" << endl; for<int i = 1; i <= n; i+> cin >> vi; int *w = new intn+1; cout << endl << "请输入每个物品的重量 <wi>:" << endl; for<int j = 1; j <= n; j+> cin >> wj; int *x = new intn+1; m = new int* n+1;/动态的分配二维数组for<int p = 0; p < n+1; p+> mp = new intc+1; knapsack <v, w, m, c, n> traceback<x, w, m, c, n> 运行结果5 / 5

    注意事项

    本文(算法设计与分析实验报告背包问题.docx)为本站会员(夺命阿水)主动上传,课桌文档仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知课桌文档(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    备案号:宁ICP备20000045号-1

    经营许可证:宁B2-20210002

    宁公网安备 64010402000986号

    课桌文档
    收起
    展开