网上有很多关于背包问题和动态规划的代码实现文章,但是如何理解动态规划的思想才是最关键的,尤其如何理解成这是一个多阶段的决策过程尤为重要,下面的这个动态规划讲解非常好,主要从两个思路来讲解动态规划,一个是利用物品个数和背包容量来说明阶段间关系,即“前i-1件物品放入剩下的容量为v-c[i]的背包中”;另一个就是直接从背包容量角度去考虑价值,新增的容量所带来的不同价值,记录各个物品新增所造成的价值变化,虽然抽象,但空间复杂度少很多。很多组合优化问题都可以归结背包问题,因为很多问题本质是因设备能力有限所造成的的瓶颈带来求解困难。
题目
有N件物品和一个容量为V的背包。第i件物品的费用是c[i],价值是w[i]。求解将哪些物品装入背包可使价值总和最大。
基本思路这是最基础的背包问题,特点是:每种物品仅有一件,可以选择放或不放。
用子问题定义状态:即f[i][v]表示前i件物品恰放入一个容量为v的背包可以获得的最大价值。则其状态转移方程便是:
f[i][v]=max{f[i-1][v],f[i-1][v-c[i]]+w[i]}
这个方程非常重要,基本上所有跟背包相关的问题的方程都是由它衍生出来的。所以有必要将它详细解释一下:“将前i件物品放入容量为v的背包中”这个子问题&#x