背包问题

✍ dations ◷ 2025-04-26 13:05:23 #最优化,运筹学,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()。

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

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

相关

  • 世界卫生组织基本药物标准清单世界卫生组织基本药物标准清单(法语:Listes modèles OMS des médicaments essentiels;英语:WHO Model List of Essential Medicines;简称EML)是世界卫生组织(WHO或称世卫组织)的出
  • 轮藻有胚植物 Embryophyta轮藻门是藻类的一门,包含了最亲近有胚植物的亲戚。因为排除了有胚植物,轮藻门是个并系群(然而有时会限定成单纯只有轮藻目,其为单系群)。藻体构造较复杂,有类
  • 影视影视在现代所指的是电影以及电视,一般用来指电视与电影作品,广义上则包括各种以视觉为载体的传播媒体。由于电影以及电视在中国的普及,越来越多的作品出现了,包括故事片、纪录片
  • 杰尔杰尔(匈牙利语:Győr;克罗地亚语:Jura、Đura或Vjura;德语:Raab,拉布;斯洛伐克语:;土耳其语:Yanık kale;塞尔维亚语:Ђур或Јанок;俄语:Дьер)是匈牙利西北部的一座城市,杰尔-莫松-
  • 神奈川县第6区神奈川县第6区是日本众议院的选区,设立于1994年。北海道 13 | 山形县 4 | 静冈县 9 | 岛根县 3 | 大分县 4福井县 3 | 山梨县 3 | 德岛县 3 | 高知县 3 | 佐贺县 3青森县 4 |
  • 造幕山站造幕山站(韩语:조막산역)是朝鲜民主主义人民共和国咸镜北道化城郡的一个铁路车站,属于平罗线。平罗线
  • 皮埃尔-让·德·贝朗瑞皮埃尔-让·德·贝朗瑞(法语:Pierre-Jean de Béranger,1780年8月19日-1857年7月16日),是十九世纪法国革命民主主义诗人。1870年8月19日上午6点出生于巴黎蒙托格伊路祖父的裁缝阁
  • 加西亚·桑切斯一世 (潘普洛纳)加西亚·桑切斯一世,有时称作加西亚一世、二世、三世或四世(西班牙语:García Sánchez I,约919年-970年2月22日)从931年到去世为潘普洛纳国王。他是潘普洛纳的桑乔一世与托达·阿
  • 卢博斯·米海尔卢博斯·米海尔(媒体常用译名是米歇尔,斯洛伐克语:Ľuboš Micheľ,1968年5月16日-),是一名斯洛伐克足球裁判,他除了母语斯洛伐克语外,更懂英语、法语、俄语,因此经常获执法国际大赛,曾
  • 肯塔基州饮食肯塔基州的饮食文化多承袭自传统美国南方饮食。常见的晚餐菜肴包括炸鲶鱼、油炸玉米饼(hushpuppy)、炸鸡和乡村煎牛排,佐以青豆、斑豆或蔬菜与猪肉慢熬而成的酱汁,搭配面包食用