算法设计与分析实验报告—01背包问题_第1页
算法设计与分析实验报告—01背包问题_第2页
算法设计与分析实验报告—01背包问题_第3页
算法设计与分析实验报告—01背包问题_第4页
算法设计与分析实验报告—01背包问题_第5页
已阅读5页,还剩1页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、算法设计与分析实验报告0/1背包问题【问题描述】给定n种物品和一个背包。物品i的重量是Wi ,其价值为Vi ,背包容量为C问应该如何选择装入背包的物品,使得装入背包中物品的总价值最大?【问题分析】0/1背包问题的可形式化描述为:给定C>0, w >0, M >0,1 G兰n,要求n找出 n 元 0/1 向量(x-i,x2,.,xn),xi 0,1, 1 <n,使得瓦WjXj兰c,而且i=1n工MX达到最大。因此0/1背包问题是一个特殊的整数规划问题。i 4n0 乞 k 乞 Wn max 二 v)xiAr nZ WjXi =1X '0,1,1 乞 i 乞 n【算法

2、设计】设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- Wi)+ Vi j _ Wim( i, j )=m(i+1,j)k Vnj >WnYm(n,j)= I00三k三Wn【算法实现】#include <iostream.h>#include<string.h>#include<iomanip.h>int min(int w, int c)int temp;if

3、 (w < c) temp = w;elsetemp = c;return temp;Int max(int w, int c)int temp;if (w > c) temp = w;elsetemp = 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

4、-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&l

5、t;<"&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&am

6、p;&&&& &" << 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;elsexi = 1;c -= wi;xn = (mnc) ? 1:0;for(int y = 1; y <= n; y+) cout &l

7、t;< xy << "t"cout << endl;return xn;void main()int n, c;int *m;cout << "&&&&&&&&&&&&&&&&&&&&& 欢 迎 使 用 0-1 背 包 问 题 程 序 &&&&&&&&&&&&&a

8、mp;&&&&&&" << 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 int

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论