5 Backpack

特点:

  1. 用值作为DP维度

  2. DP过程就是填写矩阵

  3. 可以滚动数组优化

什么是背包问题?

简单来讲,你有一个背包,它的容量为V,你同时有若干个物品,它们有各自的体积和价值,将哪些物品装入背包可以使得它们的总体积和不超过背包的容量而总价值和最大?

我们把形如这样的一类与背包有关的问题称为背包问题。

有哪些背包问题?

  1. 多重背包问题 Backpack VII,Backpack VIII

  2. 完全背包问题 Backpack III,Backpack IV

背包问题举例

有N个物品,一个容量为V的背包,第ii个物品的体积为cap[i],价值为val[i],求在不超过背包的容量限制的情况下所能获得的最大物品价值和为多少?

什么是伪多项式时间

问题:0-1 背包时间复杂度为O(VN)的动态规划解法是多项式时间算法吗?其中,V表示背包容量,N表示物品个数。

这个问题可以说是,也可以说不是。为什么呢?

说是,是因为O(VN),相对于V和N这两个数字值是多项式时间的。

说不是,是因为O(VN),相对于输入所需要的的长度 O(logV + Nlog(max(cap[i], val[i])) 是指数时间的。

我们一般把运行时间是关于输入规模(输入所需要的位的长度)为指数时间,而关于输入的数字值为多项式时间的时间称为伪多项式时间。

Last updated