背包问题

✍ dations ◷ 2025-07-04 09:11:41 #最优化,运筹学,NP完全问题,计算复杂性理论,组合数学

背包问题(Knapsack problem)是一种组合优化的NP完全问题。问题可以描述为:给定一组物品,每种物品都有自己的重量和价格,在限定的总重量内,我们如何选择,才能使得物品的总价格最高。问题的名称来源于如何选择最合适的物品放置于给定背包中。

相似问题经常出现在商业、组合数学,计算复杂性理论、密码学和应用数学等领域中。

也可以将背包问题描述为决定性问题,即在总重量不超过的前提下,总价值是否能达到。

我们有 种物品,物品 的重量为,价格为。
我们假定所有物品的重量和价格都是非负的。背包所能承受的最大重量为。
如果限定每种物品只能选择0个或1个,则问题称为0-1背包问题。

可以用公式表示为:

如果限定物品最多只能选择个,则问题称为有界背包问题。
可以用公式表示为:

如果不限定每种物品的数量,则问题称为无界背包问题。
各类复杂的背包问题总可以变换为简单的0-1背包问题进行求解。

在计算机科学领域,人们对背包问题感兴趣的原因在于:

如果重量, ..., 和都是非负数,那么用动态规划,可以用伪多项式时间解决背包问题。下面描述了无界背包问题的解法。

简便起见,我们假定重量都是正数(wj > 0)。在总重量不超过的前提下,我们希望总价格最高。对于 ≤ ,我们将在总重量不超过的前提下,总价格所能达到的最高值定义为()。()即为问题的答案。

显然,()满足:

其中,为第种物品的价格。

关于第二个公式的一个解释:总重量为时背包的最高价值可能有两种情况,第一种是该重量无法被完全填满,这对应于表达式()。第二种是刚好填满,这对应于一个包含一系列刚好填满的可能性的集合,其中的可能性是指当最后放进包中的物品恰好是重量为的物品时背包填满并达到最高价值。而这时的背包价值等于重量为物品的价值和当没有放入该物品时背包的最高价值之和。故归纳为表达式 + ( - )。最后把所有上述情况中背包价值的最大值求出就得到了()的值。

如果总重量为0,总价值也为0。然后依次计算(0), (1), ..., (),并把每一步骤的结果存入表中供后续步骤使用,完成这些步骤后()即为最终结果。由于每次计算()都需要检查种物品,并且需要计算个()值,因此动态规划解法的时间复杂度为O()。如果把, ..., , 都除以它们的最大公因数,算法的时间将得到很大的提升。

尽管背包问题的时间复杂度为O(),但它仍然是一个NP完全问题。这是因为同问题的并不成线性关系。原因在于问题的输入大小仅仅取决于表达输入所需的比特数。事实上, l o g 2 W + 1 {\displaystyle \left\lfloor log_{2}W\right\rfloor +1} 所需的比特数,同问题的输入长度成线性关系。

类似的方法可以解决0-1背包问题,算法同样需要伪多项式时间。我们同样假定, ..., 和都是正整数。我们将在总重量不超过的前提下,前种物品的总价格所能达到的最高值定义为(, )。

(, )的递推关系为:

通过计算(, )即得到最终结果。为提高算法性能,我们把先前计算的结果存入表中。因此算法需要的时间和空间都为O(),通过对算法的改进,空间的消耗可以降至O()。

推广的背包问题有二次背包问题、多维背包问题、多目标背包问题等。

二次背包问题是背包问题的一种推广形式:

相关

  • 汉他病毒汉坦病毒(Hantavirus),又译汉坦病毒,是本雅病毒目的一种病毒,其引发的病症称为汉他病/肾综合征出血热/流行性出血热,为一种经由老鼠传染给人类的致命传染病,被列为生物性危害第四级
  • 磷脂双分子层磷脂双分子层(英语:lipid bilayer 或phospholipid bilayer)是由两层磷脂分子组成的薄膜。 几乎所有细胞生物的细胞膜和许多病毒的包膜都主要由磷脂双分子层构成,此外,核被膜和
  • 摩擦力摩擦力(英语:friction)指两个表面接触的物体相对滑动时抵制它们的相对移动的力,是经典力学的一个名词。广义地,物体在液体和气体中运动时也受到摩擦力。摩擦力产生的情形:摩擦力来
  • 保罗·博尔塞利诺保罗·博尔塞利诺(于1940年1月19日出生在巴勒莫,1992年7月19日在同一个城市罹难)是一名意大利反黑法官,1992年7月19日他被黑手党的汽车炸弹谋害于巴勒莫。此前不足两个月,他的朋
  • 阿齐沙坦阿齐沙坦(又称阿齐沙坦酯,英语:Azilsartan)(INN) 是一款正处于研发中的治疗高血压症的血管紧张素II受体拮抗剂药物,多用于治疗高血压症,也是目前唯一处于末期临床的血管紧张素II受体
  • 几何形状在几何学中,几何图形或几何形状(英语:Geometric Shape)是指能利用几何学表达出来的形状,或移除了位置、大小、定向(如整体旋转角度)、手性(如镜像与否)特性的数学物件(英语:Mathematica
  • 彩度色度指的是色彩的纯度,也叫饱和度或彩度,是“色彩三属性”之一。如大红就比玫红更红,这就是说大红的色度要高。它是HSV色彩属性模式、孟塞尔颜色系统等的描述色彩变量。从广义
  • 1583年商朝第二任君主外丙继位。埃及人发明的一种全新的历法,该历法来源于月亮和星星。该历法比巴比伦历法要先进。
  • 梅尔曼–瓦格纳定理在量子场论和统计力学中,梅尔曼–瓦格纳定理(Mermin–Wagner定理,或Mermin–Wagner–Hohenberg–Berezinskii–Coleman定理)说:维度.mw-parser-output .serif{font-family:Times,
  • 威廉·班森威廉·薛佛·班森(英文:William Shepherd Benson,1855年9月25日-1932年5月)海军上将,美国海军第一任海军作战部长,同时也是第一次世界大战中,美国海军最高领导人。班森出生于乔治亚