动态规划01背包问题

动态规划是解决01背包问题的一种常用方法。01背包问题是一个经典的组合优化问题,通常描述如下:

给定一组物品,每个物品有一个重量(weight)和一个价值(value),以及一个固定容量的背包。目标是选择一些物品放入背包中,使得放入的物品的总重量不超过背包容量,同时总价值最大化。

以下是解决01背包问题的动态规划算法的基本步骤:

创建一个二维数组 dp,其中 dpij 表示在考虑前 i 个物品,且背包容量为 j 的情况下的最大价值。

初始化边界条件:

当没有物品可选时,即 i=0,dp0j 应该都为0,因为没有物品可放入背包。

当背包容量为0时,即 j=0,dpi0 也应该都为0,因为不论有多少物品,背包容量为0时无法放入任何物品。

使用动态规划递推公式填充 dp 数组。递推公式如下:

如果当前考虑的物品重量大于背包的容量,即 weighti-1 > j,则 dpij = dpi-1j,表示不能放入当前物品,最大价值与前 i-1 个物品相同。

如果当前考虑的物品重量不大于背包的容量,即 weighti-1 <= j,则需要考虑放入或不放入当前物品两种情况。取两者中的较大值:

如果不放入当前物品,即 dpij = dpi-1j

如果放入当前物品,即 dpij = dpi-1j - weight\[i-1] + valuei-1,其中 valuei-1 表示当前物品的价值。

最终 dpnW 即为解决问题的答案,其中 n 表示物品的数量,W 表示背包的容量。

下面是一个简单的Python示例代码来解决01背包问题:

def knapsack_01(weights, values, capacity):

n = len(weights)

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

for i in range(1, n + 1):

for j in range(1, capacity + 1):

if weightsi - 1 > j:

dpij = dpi - 1j

else:

dpij = max(dpi - 1j, dpi - 1j - weights\[i - 1] + valuesi - 1)

return dpncapacity

示例用法

weights = 2, 2, 3, 4, 5

values = 3, 4, 5, 6, 7

capacity = 7

print(knapsack_01(weights, values, capacity)) # 输出最大价值

这段代码将计算出给定物品和背包容量的情况下,可以获得的最大价值。

相关推荐
-森屿安年-5 天前
63. 不同路径 II
c++·算法·动态规划
林森lsjs5 天前
斐波那契数列的 N 种解法:从递归到动态规划的优化之路【算法思考】
算法·动态规划
workflower6 天前
互联网与大数据环境下制造服务模式
人工智能·自然语言处理·数据挖掘·自动驾驶·动态规划·制造
2601_961845156 天前
花生十三网课网盘|百度网盘|下载
数据结构·算法·链表·贪心算法·排序算法·线性回归·动态规划
拂拉氏6 天前
【知识讲解-题目讲解】算法系列之动态规划入门(下)
算法·leetcode·动态规划
2601_961845156 天前
花生十三图推思维导图|图形推理|技巧
数据结构·算法·链表·贪心算法·排序算法·线性回归·动态规划
workflower7 天前
使用大语言模型处理用户需求
大数据·人工智能·设计模式·重构·动态规划
青山木7 天前
Hot 100 --- 滑动窗口最大值
java·数据结构·算法·leetcode·动态规划
xhtdj8 天前
智源大会圆桌大模型没有终局具身智能可能是中国的 AlphaGo 时刻
人工智能·clickhouse·安全·动态规划
2301_764441338 天前
番茄钟+AI:高效专注的秘密武器
人工智能·算法·数学建模·动态规划·交互