多重背包
前置知识
概念:什么是多重背包
相较于01背包和完全背包,更实际的,多重背包是每一个物品有个数限制的背包,这相较于前面两个就有一点点难度了
思路:设计多重背包
首先,最最最基础的,我们可以像完全背包那样,暴力枚举每一个物品选多少次,代码时间复杂度是三次方的。
1 | for(int i = 1; i <= n; i++) // 枚举物品 |
那么,我们考虑更优的方式去选择物品。
当你面对一些奇奇怪怪的优化分组没有思路的时候,你就可以稍微考虑考虑二进制。二进制拆分,因为二进制转变为十进制的唯一性,所以我们对于物品数量二进制拆分可以优化到 $O(n\log n)$ ,代码如下:
1 | for(int i = 1; i <= n; i++) { |
实践:经典例题分析
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 祝馀宫!
评论