优化算法系列之模拟退火算法(1)——0-1背包问题
1问题描述
有一个窃贼在偷窃一家商店时发现有N件商品:第i件物品价值vi元,重wi磅,其中vi、wi都是整数。他希望带走的东西越值钱越好,但他的背包小,最多只能装下W磅的东西(W为整数)。如果每件物品或被带走或被留下,小偷应该带走哪几件东西?
2解空间
设xi表示第i件物品的取舍,1代表取,0代表舍,搜索空间为n元一维数组(x1,x2,x3,.....,xn)。因而解空间的取值范围可表示为(0,0,0,....,0),(0,0,0,......,1),(0,0,0,......,1,0),......,(1,1,1,1,......,1)。
以3个物品为例,解(0,1,0)表示(不取物品0,取物品1,不取物品2)。
3问题转化
给定W>0,wi>0,vi>0,要求找出一个n元的0-1向量(x1,x2,x3,......,xn),使得所取物品价值最大且重量之和小于W。
4求解结果
假设物品共10件,
其质量分别为8 12 24 16 6 9 35 21 18 19,
其价值分别为34 32 56 67 54 32 45 56 46 70,
背包能承受的最大质量为50。
根据模拟退火算法,通过MATLAB软件编程求得: