背包问题

✍ dations ◷ 2025-02-24 13:42:29 #最优化,运筹学,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()。

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

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

相关

  • 枸橼酸柠檬酸,化学式为 C6H8O7,(英语:Citric Acid,亦称为枸橼酸)它包括3个羧基(R-COOH)基团。是一种中强度有机酸,这是自然在柑橘类水果中产生的一种天然防腐剂,也是食物和饮料中的酸味添加
  • 郁金香参见正文郁金香在植物分类学上,是一类属于百合科郁金香属(学名:Tulipa)的具鳞茎草本植物,又称洋荷花、旱荷花、草麝香、郁香(《太平御览》)、红蓝花、紫述香(《本草纲目》),原产地从南
  • 罗马及拜占庭时期第八第十公元前30年,屋大维在击败其劲敌马克·安东尼,废除克娄巴特拉七世埃及女王之位后,吞并了托勒密埃及,并将其纳为罗马的一个行省。作为罗马行省的埃及包括了除西奈半岛之外
  • 大黄鱼大黄鱼(学名:Larimichthys crocea),又名黄花鱼,是鲈形目石首鱼科黄鱼属鱼类中的一种食用鱼。一般体长30-40厘米,体重400-800克,身体呈金黄色,尾柄长为高的3倍多。大黄鱼主要分布于中
  • 红色代表联邦直辖区联邦直辖区(马来语:Wilayah Persekutuan, 英语:Federal Territory)是马来西亚由联邦政府管辖的一级行政区,由吉隆坡、纳闽、布城三个地区组成。吉隆坡联邦直辖区于1974年成立;纳闽
  • 清卷舌近音清卷舌近音是一种辅音,使用于一些口语中。国际音标写作⟨ɻ̊⟩,X-SAMPA音标则记作r\`_0。清卷舌近音的特征包括:当符号成对出现时,左边的是清音,右边的是浊音。阴影区域表示被认
  • 玛丽亚·特蕾莎 (那不勒斯和西西里公主)玛丽亚·特蕾莎(英语:Maria Theresa,1772年6月6日-1807年4月13日)是神圣罗马帝国、奥地利皇后和那不勒斯王国公主。她的丈夫是神圣罗马帝国最后一任皇帝弗朗茨二世。1790年,玛丽亚
  • 1985年1月逝世人物列表1985年1月逝世人物列表,是用于汇总1985年1月期间逝世人物的列表。
  • 岐南町岐南町(日语:岐南町/ぎなんちょう  */?)为岐阜县南部羽岛郡的町。自2006年起成为地方交付税不交付团体。现任町长为片桐博彰。
  • Code Geass机动兵器列表本列表记载日本动画《Code Geass 反叛的鲁路修》系列及《Code Geass 亡国的阿基德》内登场的机动兵器Knightmare Frame,ナイトメアフレーム。人型兵器,又名“人型自在战斗装甲