博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
优化算法系列-模拟退火算法(1)——0-1背包问题
阅读量:5215 次
发布时间:2019-06-14

本文共 1457 字,大约阅读时间需要 4 分钟。

优化算法系列之模拟退火算法(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软件编程求得:

5求解代码

clcclear allclose alla=0.95;%温度衰减速度mar_length=1000;%马氏链长度k=[34 32 56 67 54 32 45 56 46 70];%物品价值d=[8 12 24 16 6 9 35 21 18 19];%物品重量restriction=50;%背包能够承受的最大重量num=length(k);%物品数量sol_new=round(rand(1,num));%随机生成初始解E_current=inf;E_best=inf;%E_current是当前解对应的目标函数,E_best是最优解,E_new是新解的目标函数值t0=97;tf=3;t=t0;while t>tf    for i=1:mar_length        %产生随机扰动        temp1=ceil(rand*num);        sol_new(1,temp1)=~sol_new(1,temp1);        %检查是否满足约束        while (1)            s=(sol_new*d'>restriction);            if s                %如果不满足约束随机放弃一个物品                temp2=find(sol_new==1);                temp3=ceil(rand*length(temp2));                sol_new(temp2(temp3))=~sol_new(temp2(temp3));            else                break            end        end        %计算背包中物品的价值模拟退火算法只能求最小值,所以价值取负        E_new=sol_new*(-k');        if E_new

摘录网站:

  1. 

  2.

  3. 

转载于:https://www.cnblogs.com/haimishasha/p/9785567.html

你可能感兴趣的文章
tcp服务的测试程序开源
查看>>
MySQL基础:安装
查看>>
简练网软考知识点整理-项目资源优化、资源平衡及资源平滑
查看>>
三.使用字符串
查看>>
(Gorails)vuejs系列视频: Webpacker/vue-resource(不再为官方推荐)。
查看>>
JavaScript Transpilers: 为什么需要用它们?Babel的使用介绍。
查看>>
六、Hadoop学习笔记————调优之操作系统以及JVM
查看>>
EDM营销之电子邮件的长度和宽度讲解
查看>>
react-native中的scrollables
查看>>
Spring IOC (构造器注入)
查看>>
c++面试
查看>>
servlet文件上传
查看>>
Nginx的location配置
查看>>
将图片文件转成BASE64格式
查看>>
JS最佳实践
查看>>
spring boot 在SpringMVC中使用Jackson并格式化时间
查看>>
无法安装Java,以下开关中存在错误:“0”
查看>>
spring PROPAGATION
查看>>
C#写csv文件
查看>>
MySQL知识树 查询分类
查看>>