博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
01背包
阅读量:6829 次
发布时间:2019-06-26

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

问题描述:

   有N件物品和一个载重量为C的背包。第i件物品的重量是w[i],价值是v[i]。求解将哪些物品装入背包可使这些物品的重量总和不超过背包容量,且价值总和最大。

问题特点:

   每种物品仅有一件,可以选择放或不放。(0:不放  1:放)

基本思路:

   用p[i][j]表示前i件物品放入一个容量为j的背包中可以获得的最大价值。得到如下关系:

   1.p[i][0] = p[0][j] = 0 ··········· (1)

   2.p[i][j] = p[i - 1][j] (当j < w[i]) ············· (2)

p[i][j] = max{p[i - 1][j], p[i - 1][j - w[i]] + v[i]} (当j > w[i])·············(3)

   以下解释这几个式子的含义。

   (1)式:当物品数量为0或者背包载重量为0时,显然最大价值为0.

   (2)式:当背包载重量j小于第i个物品的重量w[i]时,第i个物品无法装入背包,故此p[i][j] = p[i - 1][j]。

   (3)式:这是最关键的式子。当背包容量j大于第i个物品的重量w[i]时,产生两种选择:将第i个物品放进背包或不放进背包。由于只有两种情况,因此只需比较这两种情况下所取得的最大总价值,然后取较大者。max{···,···}中,p[i - 1][j]是不把第i件物品放进背包时所能获得的最大价值,p[i - 1][j - w[i]] + v[i]是把第i件物品放进背包时所能取得的最大价值。p[i - 1][j - w[i]] + v[i]这条式子如何理解?其实很简单。背包载重量为j,当把第i件物品放进背包时,用来容纳前i - 1件物品的容量只剩下j - w[i],p[i - 1][j - w[i]]就是前i - 1件物品在背包载重余量为j - w[i]的情况下所能取得的最大价值,再加上第i件物品的价值v[i],就得到把第i件物品放入背包时所能取得的最大价值。

 

转载地址:http://ycjkl.baihongyu.com/

你可能感兴趣的文章
Android多媒体框架图
查看>>
jps命令使用
查看>>
ADC In An FPGA
查看>>
#import &lt;/usr/include/objc/objc-class.h&gt; not such file or directory问题的解决方法
查看>>
集装箱项目
查看>>
C#中的Action<>和Func<>
查看>>
关于opencv中人脸识别主函数的部分注释详解。
查看>>
SQLServer内核架构剖析 (转载)
查看>>
Android 风格化的 Toggle Buttons
查看>>
Eclipse中SVN的安装步骤(两种)和用法
查看>>
安全运维之:网络实时流量监测工具iftop
查看>>
在 Windows上配置NativeScript CLI
查看>>
ubuntu14.04 qt4 C++开发环境搭建
查看>>
iOS 通讯录-获取联系人属性
查看>>
HTML5 文件域+FileReader 读取文件(一)
查看>>
有return的情况下try catch finally的执行顺序
查看>>
OSI七层模型具体解释
查看>>
9.中位数与顺序统计量
查看>>
第二章 知识图谱——机器大脑中的知识库
查看>>
Android 从清单配置文件元数据中获取值
查看>>