概念
背包问题是一类组合优化问题,抽象定义:
有一系列的物品,每样都有重量和价值,选择一些物品使得总的重量不超过限制,总的价值尽可能大。
背包是一种隐喻,即假设某人有固定容量的背包,怎样选择物品,使得物品的总价值最高。
应用
- 投资组合选择
- 原料最优化切割
- Merkle–Hellman 密钥的生成
1999年的一项研究表明,在组合优化工程领域的75个问题中,背包问题是处在第19位,排在后缀树和装箱问题之后。
定义
01背包问题
有界背包问题
无界背包问题
一个01背包问题
参考
https://en.wikipedia.org/wiki/Knapsack_problem
https://tangshusen.me/2019/11/24/knapsack-problem/
https://www.cnblogs.com/DAYceng/p/17301118.html
https://zh.wikipedia.org/wiki/动态规划
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构