01背包问题不同算法设计、分析与对比报告

合集下载

背包问题实验报告

背包问题实验报告

背包问题实验报告背包问题实验报告背包问题是计算机科学中的经典问题之一,它涉及到在给定的一组物品中选择一些物品放入背包中,以使得背包的总重量不超过其容量,并且所选择的物品具有最大的总价值。

在本次实验中,我们将通过不同的算法来解决背包问题,并对比它们的效率和准确性。

1. 实验背景和目的背包问题是一个重要的优化问题,它在许多实际应用中都有广泛的应用,比如货物装载、资源分配等。

在本次实验中,我们的目的是通过实际的算法实现,比较不同算法在解决背包问题时的性能差异,并分析其优缺点。

2. 实验方法和步骤为了解决背包问题,我们选择了以下几种常见的算法:贪心算法、动态规划算法和遗传算法。

下面将对每种算法的具体步骤进行介绍。

2.1 贪心算法贪心算法是一种简单而直观的算法,它通过每次选择当前状态下最优的解决方案来逐步构建最终解决方案。

在背包问题中,贪心算法可以按照物品的单位价值进行排序,然后依次选择单位价值最高的物品放入背包中,直到背包的容量达到上限。

2.2 动态规划算法动态规划算法是一种基于递推关系的算法,它通过将原问题分解为多个子问题,并利用子问题的解来构建原问题的解。

在背包问题中,动态规划算法可以通过构建一个二维数组来记录每个子问题的最优解,然后逐步推导出整个问题的最优解。

2.3 遗传算法遗传算法是一种模拟生物进化的算法,它通过模拟自然选择、交叉和变异等过程来搜索问题的最优解。

在背包问题中,遗传算法可以通过表示每个解决方案的染色体,然后通过选择、交叉和变异等操作来不断优化解决方案,直到找到最优解。

3. 实验结果和分析我们使用不同算法对一组测试数据进行求解,并对比它们的结果和运行时间进行分析。

下面是我们的实验结果:对于一个容量为10的背包和以下物品:物品1:重量2,价值6物品2:重量2,价值10物品3:重量3,价值12物品4:重量4,价值14物品5:重量5,价值20贪心算法的结果是选择物品4和物品5,总重量为9,总价值为34。

算法设计与分析实验报告——基于回溯法的0-1背包等问题

算法设计与分析实验报告——基于回溯法的0-1背包等问题

实验报告. 基于回溯法的0-1背包等问题实验内容本实验要求基于算法设计与分析的一般过程(即待求解问题的描述、算法设计、算法描述、算法正确性证明、算法分析、算法实现与测试),通过回溯法的在实际问题求解实践中,加深理解其基本原理和思想以及求解步骤。

求解的问题为0-1背包。

作为挑战:可以考虑回溯法在如最大团、旅行商、图的m着色等问题中的应用。

实验目的◆理解回溯法的核心思想以及求解过程(确定解的形式及解空间组织,分析出搜索过程中的剪枝函数即约束函数与限界函数);◆掌握对几种解空间树(子集树、排列数、满m叉树)的回溯方法;◆从算法分析与设计的角度,对0-1背包等问题的基于回溯法求解有进一步的理解。

环境要求对于环境没有特别要求。

对于算法实现,可以自由选择C, C++或Java,甚至于其他程序设计语言如Python等。

实验步骤步骤1:理解问题,给出问题的描述。

步骤2:算法设计,包括策略与数据结构的选择。

步骤3:描述算法。

希望采用源代码以外的形式,如伪代码或流程图等;步骤4:算法的正确性证明。

需要这个环节,在理解的基础上对算法的正确性给予证明;步骤5:算法复杂性分析,包括时间复杂性和空间复杂性;步骤6:算法实现与测试。

附上代码或以附件的形式提交,同时贴上算法运行结果截图;步骤7:技术上、分析过程中等各种心得体会与备忘,需要言之有物。

说明:步骤1-6在“实验结果”一节中描述,步骤7在“实验总结”一节中描述。

实验结果步骤1:问题描述。

给定 n个物品,其中第 i 个物品的重量为w i ,价值为 v i 。

有一容积为 W 的背包,要求选择一些物品放入背包,使得物品总体积不超过W的前提下,物品的价值总和最大。

0-1背包问题的限制是,每种物品只有一个,它的状态只有放和不放两种。

0-1背包问题是特殊的整数规划问题,其可用数学语言表述为:对于给定 n >0,W >0,v,w (v i ,w i >0,1≤i ≤n),找出一个 n 元0-1向量x =( x 1, x 2,⋯, x n ) 其中x i ∈{0,1},1≤i ≤n ,使得∑v i n i=1x i 最大,并且∑w i n i=1x i ≤W ,即:max x (∑v i ni=1x i ) s.t.∑w i ni=1x i ≤W, x i ∈{0,1},1≤i ≤n步骤2:算法设计,即算法策略与数据结构的选择。

算法分析与设计实验报告之01背包问题

算法分析与设计实验报告之01背包问题

算法分析与设计实验报告[0/1背包问题]0/1背包问题的不同算法解决方案组员02黄希龙 09455321张育强05周麒目录一.问题描述 (1)二.算法分析 (2)1.穷举法: (2)2.递归法: (4)3.贪心法: (5)4.动态规划法分析: (6)5.回溯法分析: (7)6.分支限界法: (9)三.时空效率分析 (10)1.穷举法: (10)2.递归法: (11)3.动态规划法: (11)4.回溯法: (11)5分支限界法: (11)四.运行结果 (12)1.穷举法输出结果: (12)2.递归法输出结果: (13)3.动态规划法输出结果: (14)4.回溯法输出结果: (15)5.分支限界法输出结果: (16)五.分析输出结果 (17)六.总结与反思 (18)一.问题描述0/1背包问题:现有n 种物品,对1<=i<=n ,已知第i 种物品的重量为正整数W i ,价值为正整数V i ,背包能承受的最大载重量为正整数W ,现要求找出这n 种物品的一个子集,使得子集中物品的总重量不超过W 且总价值尽量大。

(注意:这里对每种物品或者全取或者一点都不取,不允许只取一部分)二.算法分析根据问题描述,可以将其转化为如下的约束条件和目标函数:)2(max )1()1}(1,0{11∑∑==⎪⎩⎪⎨⎧≤≤∈≤ni i i ini i i x v n i x Wx w 于是,问题就归结为寻找一个满足约束条件(1),并使目标函数式(2)达到最大的解向量),......,,,(321n x x x x X =。

首先说明一下0-1背包问题拥有最优解。

假设),......,,,(321n x x x x 是所给的问题的一个最优解,则),......,,(32n x x x 是下面问题的一个最优解:∑∑==⎪⎩⎪⎨⎧≤≤∈-≤ni i i ini i i x v n i x x w W x w 2211max )2}(1,0{。

算法设计与分析实验报告—01背包问题

算法设计与分析实验报告—01背包问题

算法设计与分析实验报告—0/1背包问题-【问题描述】给定n 种物品和一个背包。

物品i 的重量是iw ,其价值为i v,背包容量为C 。

问应该如何选择装入背包的物品,使得装入背包中物品的总价值最大?【问题分析】0/1背包问题的可形式化描述为:给定C>0, i w >0, i v >0,1i n ≤≤,要求找出n 元0/1向量{}12(,,...,),0,1,1n i x x x x i n ∈≤≤,使得n1i i i w x c =≤∑,而且n1i ii v x=∑达到最大。

因此0/1背包问题是一个特殊的整数规划问题。

0n k w ≤≤1max ni i i v x =∑n1i ii w xc =≤∑{}0,1,1i x i n ∈≤≤【算法设计】设0/1背包问题的最优值为m( i, j ),即背包容量是j ,可选择物品为i,i+1,…,n 时0/1背包问题的最优值。

由0/1背包问题的最优子结构性质,可以建立计算m( i, j )的递归式如下:max{m( i+1, j ), m( i+1, j-i w )+i v } i j w ≥m( i, j )=m(i+1,j)n v n j w >m(n,j)=0 0n k w ≤≤【算法实现】#include <iostream.h> #include<string.h> #include<iomanip.h>int min(int w, int c) {int temp; if (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(w[n]-1, c);for (int j = 0; j <= jmax; j++)m[n][j] = 0;for (int jj = w[n]; jj <= c; jj++)m[n][jj] = v[n];for(int i = n-1; i > 1; i--)//递归部分{jmax = min(w[i]-1, c);for(int j = 0; j <= jmax; j++)m[i][j] = m[i+1][j];for(int jj = w[i]; jj <= c; jj++)m[i][jj] = max(m[i+1][jj], m[i+1][jj-w[i]]+v[i]);}m[1][c] = m[2][c];if(c >= w[1])m[1][c] = max(m[1][c], m[2][c-w[1]]+v[1]);cout << endl << "最优值:" << m[1][c] << 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(m[i][c] == m[i+1][c]) x[i] = 0;else{x[i] = 1;c -= w[i];}}x[n] = (m[n][c]) ? 1:0;for(int y = 1; y <= n; y++)cout << x[y] << "\t";cout << endl;return x[n];}void main(){int n, c;int **m;cout << "&&&&&&&&&&&&&&&&&&&&&欢迎使用0-1背包问题程序&&&&&&&&&&&&&&&&&&&" << endl;cout << "请输入物品个数: ";cin >> n ;cout << endl << "请输入背包的承重:";cin >> c;int *v = new int[n+1];cout << endl << "请输入每个物品的价值 (v[i]): " << endl;for(int i = 1; i <= n; i++)cin >> v[i];int *w = new int[n+1];cout << endl << "请输入每个物品的重量 (w[i]): " << endl;for(int j = 1; j <= n; j++)cin >> w[j];int *x = new int[n+1];m = new int* [n+1]; //动态的分配二维数组for(int p = 0; p < n+1; p++)m[p] = new int[c+1];knapsack (v, w, m, c, n);traceback(x, w, m, c, n);}【运行结果】。

01背包实验报告

01背包实验报告

算法设计与分析实验报告0_1背包一.问题描述假设有n件物品,每件物品有各自的重量W1,W2,……,Wn和与之对应的价值V1,V2,……,Vn。

设背包的容量为c,在不超过背包容量的前提下,求出获得最大价值总和的方案。

(0-1背包的情况下物品不可分割,只能选择放入,或者不放入背包中)。

二.求解思路1.贪心策略问题开始阶段,将所有物品按价值从高到低排列,每一次往背包里放入不超过背包容量的价值最大的物品,直到没有物品可放入为止。

但事实证明,由于物品的不可分割性,0-1背包并不适合贪心策略。

例:假设背包的容量为50,共有三件物品(重量,价值):(10,60),(20,100),(30,120)。

若使用贪心策略,则会选择一个(30,120)和一个(20,100)。

得到的价值总和是220。

而稍加计算便可知选取两个(20,100)和一个(10,60)可以得到更大的价值总和260。

因此贪心策略不能给出0-1背包的最优解。

后话:即使是普通背包问题(物品可分割),每次选择价值最大的物品也不能得到最优解。

正确的贪心策略应是:每次选择单位重量下价值最大的物品。

由于本次实验主要讨论的是0-1背包问题,这里就不给出该贪心策略的证明。

2.动态规划(1)证明0-1背包问题具有最优子结构性质:假设(x1,x2,……,xn)是容量为c的背包的一组最优解,其中xi的取值为0或1,表示是否放入背包中。

则必有(x2,x3,……,xn)为如下子问题的一组最优解:sum{xi*wi} (2<=i<=n)<=c-x1*w1利用反证法证明,假设(y1,y2,……,yn)是该子问题的一组最优解而(x2,x3,……,xn)不是。

则sum{yi*vi} > sum{xi*vi} (2<=i<=n)那么就可得到:x1*v1+ sum{yi*vi} > x1*v1+ sum{xi*vi} (2<=i<=n)则(x1,y2,……,yn)是原问题的最优解,而(x1,x2,……,xn)不是,与假设矛盾。

01背包问题多种解法

01背包问题多种解法

一、问题描绘0/1 背包问题 :现有 n 种物件,对1<=i<=n,已知第i 种物件的重量为正整数W i,价值为正整数V i,背包能蒙受的最大载重量为正整数W ,现要求找出这n 种物件的一个子集,使得子集中物品的总重量不超出W 且总价值尽量大。

(注意:这里对每种物件或许全取或许一点都不取,不一样意只取一部分)二、算法剖析依据问题描绘,能够将其转变为以下的拘束条件和目标函数:nw i x i W(1)i1x i{ 0,1}( 1i n)nmax v i x i (2)i1于是,问题就归纳为找寻一个知足拘束条件( 1 ),并使目标函数式( 2 )达到最大的解向量 X(x1, x2 , x3 ,......, x n ) 。

第一说明一下0-1 背包问题拥有最优解。

假定 (x1, x2 , x3 ,......, x n ) 是所给的问题的一个最优解,则 (x2 , x3,......, x n ) 是下边问题的nw i x i W w1x1 maxn一个最优解:i 2v i x i。

假如不是的话,设( y2, y3 ,......, y n ) 是这x i{ 0,1}( 2i n)i 2n n n个问题的一个最优解,则v i y i v i x i,且 w1x1w i y i W 。

因此,i 2i 2i 2n n nv1x1v i y i v1 x1v i x i v i x i,这说明 (x1, y2 , y3 ,........, y n ) 是所给的0-1 背包问i 2i 2i 1题比 ( x1 , x2 , x3 ,........, x n ) 更优的解,进而与假定矛盾。

穷举法:用穷举法解决0-1 背包问题,需要考虑给定n 个物件会合的所有子集,找出所有可能的子集(总重量不超出背包重量的子集),计算每个子集的总重量,而后在他们中找到价值最大的子集。

因为程序过于简单,在这里就不再给出,用实例说明求解过程。

01背包问题不同算法设计、分析与对比

01背包问题不同算法设计、分析与对比

实验三01背包问题不同算法设计、分析与对比一.问题描述给定n种物品和一背包。

物品i的重量是wi ,其价值为vi,背包的容量为c。

问题:应如何选择装入背包中的物品,使得装入背包中物品的总价值最大。

说明:在选择装入背包的物品时,对每种物品i只有两个选择,装入背包或不装入背包,也不能将物品装入背包多次。

二.实验内容与要求实验内容:1.分析该问题适合采用哪些算法求解(包括近似解)。

动态规划、贪心、回溯和分支限界算法。

2.分别给出不同算法求解该问题的思想与算法设计,并进行算法复杂性分析。

动态规划:递推方程:m(i,j) = max{m(i-1,j),m(i-1,j-wi)+vi} j >= wi;m(i-1,j) j < wi;时间复杂度为O(n).贪心法:算法思想:贪心原则为单位价值最大且重量最小,不超过背包最大承重量为约束条件。

也就是说,存在单位重量价值相等的两个包,则选取重量较小的那个背包。

但是,贪心法当在只有在解决物品可以分割的背包问题时是正确的。

贪心算法总是作出在当前看来最好的选择。

也就是说贪心算法并不从整体最优考虑,它所作出的选择只是在某种意义上的局部最优选择。

用贪心法设计算法的特点是一步一步地进行,根据某个优化测度(可能是目标函数,也可能不是目标函数),每一步上都要保证能获得局部最优解。

每一步只考虑一个数据,它的选取应满足局部优化条件。

若下一个数据与部分最优解连在一起不再是可行解时,就不把该数据添加到部分解中,直到把所有数据枚举完,或者不能再添加为止。

回溯法:回溯法:为了避免生成那些不可能产生最佳解的问题状态,要不断地利用限界函数(bounding function)来处死那些实际上不可能产生所需解的活结点,以减少问题的计算量。

这种具有限界函数的深度优先生成法称为回溯法。

对于有n种可选物品的0/1背包问题,其解空间由长度为n的0-1向量组成,可用子集数表示。

在搜索解空间树时,只要其左儿子结点是一个可行结点,搜索就进入左子树。

背包问题实验报告

背包问题实验报告

0-1背包问题实验报告一:0-1背包问题给定n种物品和一个背包。

物品i的重量是Wi,其价值为Vi,背包的容量为c。

问应如何选择装入背包中的物品,使得装入背包中物品的总价值最大?在选择装入背包的物品时,对每种物品i只有两种选择,装入或者不装入背包。

不能将物品i多次装入,也不能装入部分的物品i。

因此,该问题被称为0-1背包问题。

本次针对0-1背包问题的实验,主要使用动态规划的方法、贪心算法、回溯法以及分支限界法。

测试用例为:n=50,c=1000,每个物品重量为{220,208,198,192,180,180,165,162,160,158,155,130,125,122,120,118,115,110,105,1 01,100,100,98,96,95,90,88,82,80,77,75,73,70,69,66,65,63,60,58,56,50,30,20,15,10,8,5 ,3,1,1}每个物品价值为{80,82,85,70,72,70,66,50,55,25,50,55,40,48,50,32,22,60,30,32,40,38,35,32,25,28 ,30,22,50,30,45,30,60,50,20,65,20,25,30,10,20,25,15,10,10,10,4,4,2,1} 下面将分别谈论。

二:动态规划法1:基本思想:动态规划算法的基本思想是将待求解问题分解成若干个子问题,先求解子问题,然后从这些子问题的解得到原问题的解。

其经过分解得到的子问题往往不是相互独立的,可以用一张表来记录所有已解决的子问题的答案,而不论该子问题以后是否会用到。

从而使得子问题避免重复计算。

2:设计步骤:动态规划算法适用于解最优化问题,通常可按以下几步设计:(1)找出最优解的特性,并刻画其结构特征。

(2)递归地定义最优值。

(3)以自底向上的方式计算出最优值。

(4)根据计算最优值时得到的信息,构造最优解。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

实验三01背包问题不同算法设计、分析与对比一.问题描述给定n种物品和一背包。

物品i的重量是wi ,其价值为vi,背包的容量为c。

问题:应如何选择装入背包中的物品,使得装入背包中物品的总价值最大。

说明:在选择装入背包的物品时,对每种物品i只有两个选择,装入背包或不装入背包,也不能将物品装入背包多次。

二.实验内容与要求实验内容:1.分析该问题适合采用哪些算法求解(包括近似解)。

^动态规划、贪心、回溯和分支限界算法。

2.分别给出不同算法求解该问题的思想与算法设计,并进行算法复杂性分析。

动态规划:递推方程:m(i,j) = max{m(i-1,j),m(i-1,j-wi)+vi} j >= wi;m(i-1,j) j < wi;时间复杂度为O(n).贪心法:^算法思想:贪心原则为单位价值最大且重量最小,不超过背包最大承重量为约束条件。

也就是说,存在单位重量价值相等的两个包,则选取重量较小的那个背包。

但是,贪心法当在只有在解决物品可以分割的背包问题时是正确的。

贪心算法总是作出在当前看来最好的选择。

也就是说贪心算法并不从整体最优考虑,它所作出的选择只是在某种意义上的局部最优选择。

用贪心法设计算法的特点是一步一步地进行,根据某个优化测度(可能是目标函数,也可能不是目标函数),每一步上都要保证能获得局部最优解。

每一步只考虑一个数据,它的选取应满足局部优化条件。

若下一个数据与部分最优解连在一起不再是可行解时,就不把该数据添加到部分解中,直到把所有数据枚举完,或者不能再添加为止。

回溯法:回溯法:为了避免生成那些不可能产生最佳解的问题状态,要不断地利用限界函数(bounding function)来处死那些实际上不可能产生所需解的活结点,以减少问题的计算量。

这种具有限界函数的深度优先生成法称为回溯法。

对于有n种可选物品的0/1背包问题,其解空间由长度为n的0-1向量组成,可用子集数表示。

在搜索解空间树时,只要其左儿子结点是一个可行结点,搜索就进入左子树。

当右子树中有可能包含最优解时就进入右子树搜索。

时间复杂度为:O(2n)空间复杂度为:O(n):分支限界算法:首先,要对输入数据进行预处理,将各物品依其单位重量价值从大到小进行排列。

在优先队列分支限界法中,节点的优先级由已装袋的物品价值加上剩下的最大单位重量价值的物品装满剩余容量的价值和。

算法首先检查当前扩展结点的左儿子结点的可行性。

如果该左儿子结点是可行结点,则将它加入到子集树和活结点优先队列中。

当前扩展结点的右儿子结点一定是可行结点,仅当右儿子结点满足上界约束时才将它加入子集树和活结点优先队列。

当扩展到叶节点时为问题的最优值。

3.设计并实现所设计的算法。

4.对比不同算法求解该问题的优劣。

这动态规划算法和贪心算法是用来分别解决不同类型的背包问题的,当一件背包物品可以分割的时候,使用贪心算法,按物品的单位体积的价值排序,从大到小取即可。

当一件背包物品不可分割的时候,(因为不可分割,所以就算按物品的单位体积的价值大的先取也不一定是最优解)此时使用贪心是不对的,应使用动态规划。

5.需要提交不同算法的实现代码和总结报告。

动态规划方法:public class Knapsack {public static void main(String[] args) {|int[] value = { 0, 60, 100, 120 };int[] weigh = { 0, 10, 20, 30 };int weight = 50;Knapsack1(weight, value, weigh);}public static void Knapsack1(int weight, int[] value, int[] weigh) { int[] v = new int[];;int[] w = new int[];int[][] c = new int[][weight + 1];int d[] = new int [100];for (int i = 0; i < ; i++) {v[i] = value[i];w[i] = weigh[i];}for (int i = 1; i < ; i++) {&for (int k = 1; k <= weight; k++) {if (w[i] <= k) {c[i][k] = max(c[i - 1][k], c[i - 1][k - w[i]] + v[i]);} else {c[i][k] = c[i - 1][k];}}}-- 1][weight]);}private static int max(int i, int j) {int k = i > j i : j;return k;}}:贪心法:public class GreedyKnapSack {public static void main(String[] args) {int[] value = { 0, 60, 100, 120 };int[] weigh = { 0, 10, 20, 30 };int weight = 50;Knapsack1(weight, value, weigh);}—private static void Knapsack1(int weight, int[] v, int[] w) { int n = ;double[] r = new double[n];int[] index = new int[n];for(int i = 0;i < n; i++) {r[i] = (double)v[i] / (double)w[i];index[i] = i;《}//按单位重量价值r[i]=v[i]/w[i]降序排列double temp = 0;for(int i = 0;i < n-1;i++){for(int j = i+1;j < n;j++){if(r[i] < r[j]){temp = r[i];r[i] = r[j];&r[j] = temp;int x = index[i];index[i] = index[j];index[j] = x;}}}//排序后的重量和价值分别存到w1[]和v1[]中—int[] w1 = new int[n];int[] v1 = new int[n];for(int i = 0;i < n;i++){w1[i] = w[index[i]];v1[i] = v[index[i]];}(w1));(v1));~int s=0;//包内现存货品的重量int value=0;//包内现存货品总价值for(int i = 0; i < n;i++){if(s + w1[i] < weight){value += v1[i];s += w1[i];}};"背包中物品的最大总价值为" + value);}}回溯法:public class BacktrackKnapSack {public static void main(String[] args) {int[] value = { 0, 60, 100, 120 };int[] weigh = { 0, 10, 20, 30 };'int weight = 50;Knapsack1(weight, value, weigh);}private static void Knapsack1(int weight, int[] v, int[] w) { int n = ;double[] r = new double[n];int[] index = new int[n];:for(int i = 0;i < n; i++) {r[i] = (double)v[i] / (double)w[i];index[i] = i;}//按单位重量价值r[i]=v[i]/w[i]降序排列double temp = 0;for(int i = 0;i < n-1;i++){for(int j = i+1;j < n;j++){#if(r[i] < r[j]){temp = r[i];r[i] = r[j];r[j] = temp;int x = index[i];index[i] = index[j];index[j] = x;}~}}//排序后的重量和价值分别存到w1[]和v1[]中int[] w1 = new int[n];int[] v1 = new int[n];for(int i = 0;i < n;i++){w1[i] = w[index[i]];v1[i] = v[index[i]];}}//调用函数KnapSackBackTrack(),输出打印装完物品以后的最大价值KnapSackBackTrack(w1,v1,,weight);}private static void KnapSackBackTrack(int[] w1, int[] v1, int length, int weight) {int CurrentWeight = 0;。

int CurrentValue = 0;int maxValue = 0;int i = 0;int n = ;while(i >= 0){if(CurrentWeight + w1[i] < weight){CurrentWeight += w1[i];CurrentValue += v1[i];(i++;}elsebreak;}if(i < n){maxValue = CurrentValue;"1背包中物品的最大总价值为" + maxValue);<}}}分支限界算法:package bag01b;import class bag01do {—public static void main(String[] args) {// TODO Auto-generated method stubArrayList<object> objects=new ArrayList<>();(new object(10,60));(new object(20,100));(new object(30,120));bag b=new bag(50,objects);();{();}}-----------------------------------------------------------------------package bag01b;import class bag {private int bagv;#private ArrayList<object> objects;private int maxvalue;private ArrayList<object> result_objects;public bag(int v,ArrayList<object> o){super();=v;=o;~=0;=null;(objects);}public void show(){"maxvalue :"+ ;"the object when maxvalue:"+;:}public void findmaxvalue(){PriorityQueue<Node> enode=new PriorityQueue<>();Node node=new Node(0,null,bagv,;(node);while(true){if())-break;node=();if()){=();=new ArrayList<>());return;}int i=();#object iobject= if()+()<={ArrayList<object> newnodeinbag=new ArrayList<object>());(iobject);int newnodebagv=()();Node newnode=new Node(i+1,newnodeinbag,newnodebagv,;(newnode);if()>{=();~=new ArrayList<>());}}Node newnode=new Node(i+1,(),(),;if()>(newnode);}}·}-----------------------------------------------------------------------package bag01b;import class Node implements Comparable<Node>{private int node_in;private ArrayList<object> inbag_object;private ArrayList<object> outbag_object;!private int leftv;private int prio;public Node(int i,ArrayList<object> in,int l,ArrayList<object> out){ super();=i;if(in==null)in=new ArrayList<>();=in;`=l;=out;=();}private int find_prio() {// TODO Auto-generated method stubint bag_left=;]int p=();int i=;object iobject=null;while(true){if(i>= break;iobject= if()>bag_left)break;|bag_left-=();p+=();i++;}if(i<= p+=()*bag_left;return p;}public int get_bag_weight(){.int w=0;for(object o:{w+=();}return w;}public int get_bag_value(){int w=0;!for(object o:{w+=();}return w;}@Overridepublic int compareTo(Node o) {// TODO Auto-generated method stub@if> return -1;if< return 1;return 0;}public boolean isend(){if== return true;elsereturn false;,}public ArrayList<object> get_in_bag_object(){return ;}public int get_node_in(){return ;}public int get_bag_leftv(){return ;}public int get_bag_prio(){return ;}public String toString(){return"node in"++"node prio"+;}}-----------------------------------------------------------------------package bag01b;public class object implements Comparable<object>{private static int ids=1;private int id;private int weihgt;private int value;public object(int w,int v){super();=w;=v;=ids++;}public int getid(){return ;}public int getweight(){return ;}public int getvalue(){return ;}public float getvw(){return (float);}@Overridepublic int compareTo(object o) {// TODO Auto-generated method stubif()>()) return -1;if()<()) return 1;return 0;}public String toString(){return"object "++" ";}}。

相关文档
最新文档