0-1背包问题求解_假设现在有4个物品,每个物品重量为{2,1,3,2},价值为{12,10,20,15},背包容量为5(1)

img
img

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

| — | — | — | — | — | — | — | — | — | — | — | — | — | — | — | — | — |
| dp | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| 2 | 0 | 2 | 3 | 3 | 3 | 3 | 3 | 3 | 3 | 3 | 3 | 3 | 3 | 3 | 3 | 3 |
| 3 | 0 | 2 | 3 | 4 | 5 | 5 | 5 | 5 | 5 | 5 | 5 | 5 | 5 | 5 | 5 | 5 |
| 4 | 0 | 2 | 3 | 4 | 10 | 12 | 13 | 14 | 15 | 15 | 15 | 15 | 15 | 15 | 15 | 15 |
| 5 | 0 | 2 | 3 | 4 | 10 | 12 | 13 | 14 | 15 | 15 | 15 | 15 | 15 | 15 | 15 | 15 |

(4)状态转移解释,以第4行为例:

当背包容量为0时,考虑物品(1,2,3,4),最大价值为0

当背包容量为1时,考虑物品(1,2,3,4),最大价值为2,装物品2

当背包容量为2时,考虑物品(1,2,3,4),最大价值为3,装物品1和物品2

当背包容量为3时,考虑物品(1,2,3,4),最大价值为4,装物品2和物品3

当背包容量为4时,考虑物品(1,2,3,4),最大价值为10,装物品4

此时 i = 4, j = 4, max_i = dp[i-1][j] = dp[3][4] = 5, 装物品1和物品2和物品3

此时 j = 4 >= w[i-1] = 4

因此 dp[i-1][j-w[i-1]] + v[i-1] = dp[3][0] + v[3] = 0 + 10 = 10

因此 max(max_i, dp[i-1][j-w[i-1]] + v[i-1]) = max(5, 10) = 10

因此 dp[4][4] = 10

状态解释为:当容量足够考虑装入物品4时,将物品4装入,并加上剩余空间所能装入的最大值dp[3][0]与前基准dp[4][3]即没有考虑物品4时的状态最大值进行比较,取最大。

文字解释:整体最优 = max(不考虑物品4时的最优解,考虑物品4时的最优解)

dp[i][j] = max(dp[i-1][j], dp[i-1][j-w[i-1]] + v[i-1])

代码

w = [1, 1, 2, 4, 12]
v = [1, 2, 2, 10, 4]
n = 15
m = len(w)
dp = [[0]*(n+1) for _ in range(m+1)]
for i in range(1, m+1):
    for j in range(1, n+1):
        max_i = dp[i-1][j]
        if j >= w[i-1]:
            max_i = max(max_i, dp[i-1][j-w[i-1]] + v[i-1])
        dp[i][j] = max_i
print(dp[m][n])

总结

最终得到结果,装入物品1,物品2,物品3,物品4的价值最大,为15$。

进阶

img
img

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值