背包问题算法

背包问题算法

0-1背包问题

问题:背包的容量为9,有重量分别为[2, 4, 6, 9]的四个物品,价值分别为[3, 4, 5, 6],求背包能装的物品的最大价值是多少,每种物品的数量最多为1

二维数组

python 复制代码
w = [2, 4, 6, 9]  # 重量
v = [3, 4, 5, 6]  # 价值
c = 9  # 最大容量
n = len(w)  # 物品数量
w.insert(0, 0)
v.insert(0, 0)
dp = [[0] * (c + 1) for _ in range(n + 1)]
for i in range(1, n + 1):
    for j in range(1, c + 1): # 正向
        if j >= w[i]:
            dp[i][j] = max(dp[i - 1][j], dp[i - 1][j - w[i]] + v[i])
        else:
            dp[i][j] = dp[i - 1][j]

for rows in dp:
    print(rows)
print('最大value:', dp[n][c])

一维数组

python 复制代码
w = [2, 4, 6, 9]  # 重量
v = [3, 4, 5, 6]  # 价值
c = 9  # 最大容量

n = len(w)  # 物品数量
w.insert(0, 0)
v.insert(0, 0)
dp = [0] * (c + 1)
for i in range(1, n + 1):
    for j in range(c, 0, -1): # 逆向
        if j >= w[i]:
            dp[j] = max(dp[j], dp[j - w[i]] + v[i])
    print(dp)
print('最大value:', dp[c])

完全背包问题

问题:背包的容量为9,有重量分别为[2, 4, 6, 9]的四个物品,价值分别为[3, 4, 5, 6],求背包能装的物品的最大价值是多少,每种物品的数量最多不限

二维数组

python 复制代码
w = [2, 4, 6, 9]  # 重量
v = [3, 4, 5, 6]  # 价值
c = 9  # 最大容量

n = len(w)
w.insert(0, 0)
v.insert(0, 0)

dp = [[0] * (c + 1) for _ in range(n + 1)]

for i in range(1, n + 1):
    for j in range(1, c + 1): # 正向
        if j >= w[i]:
            dp[i][j] = max(dp[i - 1][j], dp[i][j - w[i]] + v[i])
        else:
            dp[i][j] = dp[i - 1][j]
for values in dp:
    print(values)
print('最大value:', dp[n][c])

一维数组

python 复制代码
w = [2, 4, 6, 9]  # 重量
v = [3, 4, 5, 6]  # 价值
c = 9  # 最大容量

n = len(w)

w.insert(0, 0)
v.insert(0, 0)

dp = [0] * (c + 1)

for i in range(1, n + 1):
    for j in range(0, c + 1): # 正向
        if j >= w[i]:
            dp[j] = max(dp[j], dp[j - w[i]] + v[i])
    print(dp)
print('最大value:', dp[c])

多重背包问题

问题:背包的容量为10,有重量分别为[2, 4, 6, 9]的四个物品,价值分别为[3, 4, 5, 6],求背包能装的物品的最大价值是多少,每种物品的数量最多分别为[2, 1, 2, 1]

一维数组

python 复制代码
w = [2, 4, 6, 9]  # 重量
v = [3, 4, 5, 6]
counts = [2, 1, 2, 1]  # 数量
c = 10  # 最大容量
n = len(w)

w.insert(0, 0)
v.insert(0, 0)
counts.insert(0, 0)

dp = [0] * (c + 1)

for i in range(1, n + 1):
    for j in range(c, 0, -1): # 逆向
        for k in range(1, counts[i] + 1):
            if j >= k * w[i]:
                dp[j] = max(dp[j], dp[j - k * w[i]] + v[i])
    print(dp)
print('最大value:', dp[c])
相关推荐
像风一样的男人@7 分钟前
python --读取psd文件
开发语言·python·深度学习
A尘埃13 分钟前
超市购物篮关联分析与货架优化(Apriori算法)
算法
薛定谔的猫喵喵15 分钟前
天然气压力能利用系统综合性评价平台:基于Python和PyQt5的AHP与模糊综合评价集成应用
开发语言·python·qt
.小墨迹19 分钟前
apollo学习之借道超车的速度规划
linux·c++·学习·算法·ubuntu
yuluo_YX20 分钟前
Reactive 编程 - Java Reactor
java·python·apache
独好紫罗兰27 分钟前
对python的再认识-基于数据结构进行-a004-列表-实用事务
开发语言·数据结构·python
ZH154558913130 分钟前
Flutter for OpenHarmony Python学习助手实战:模块与包管理的实现
python·学习·flutter
不穿格子的程序员30 分钟前
从零开始刷算法——贪心篇1:跳跃游戏1 + 跳跃游戏2
算法·游戏·贪心
大江东去浪淘尽千古风流人物32 分钟前
【SLAM新范式】几何主导=》几何+学习+语义+高效表示的融合
深度学习·算法·slam
choke23339 分钟前
[特殊字符] Python异常处理
开发语言·python