背包问题算法

背包问题算法

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])
相关推荐
跟橙姐学代码1 天前
自动化邮件发送的终极秘籍:Python库smtplib与email的完整玩法
前端·python·ipython
扯淡的闲人1 天前
多语言编码Agent解决方案(2)-后端服务实现
开发语言·python·深度学习
蒋星熠1 天前
深度学习实战指南:从神经网络基础到模型优化的完整攻略
人工智能·python·深度学习·神经网络·机器学习·卷积神经网络·transformer
吃着火锅x唱着歌1 天前
LeetCode 1446.连续字符
算法·leetcode·职场和发展
愚润求学1 天前
【贪心算法】day10
c++·算法·leetcode·贪心算法
万粉变现经纪人1 天前
如何解决pip安装报错ModuleNotFoundError: No module named ‘cuml’问题
python·scrapy·beautifulsoup·pandas·ai编程·pip·scipy
吴秋霖1 天前
主流反爬虫、反作弊防护与风控对抗手段
爬虫·算法·反爬虫技术
IT学长编程1 天前
计算机毕业设计 基于Hadoop豆瓣电影数据可视化分析设计与实现 Python 大数据毕业设计 Hadoop毕业设计选题【附源码+文档报告+安装调试
大数据·hadoop·python·django·毕业设计·毕业论文·豆瓣电影数据可视化分析
java1234_小锋1 天前
Scikit-learn Python机器学习 - 分类算法 - K-近邻(KNN)算法
python·算法·机器学习
智者知已应修善业1 天前
【矩阵找最大小所在位置】2022-11-13
c语言·c++·经验分享·笔记·算法·矩阵