介绍一下背包DP(Python)

背包问题概述

背包问题是一类经典的动态规划问题,分为0-1背包完全背包两种主要类型。核心思想是通过状态转移方程逐步填充一个二维数组(或优化后的一维数组),记录不同容量下的最优解。


0-1背包问题

问题描述 :给定物品的重量 weights 和价值 values,以及背包容量 capacity,每个物品只能选或不选,求最大价值。

动态规划解法

状态定义
dp[i][j] 表示前 i 个物品在容量 j 下的最大价值。

状态转移方程

复制代码
dp[i][j] = max(dp[i-1][j], dp[i-1][j-weights[i-1]] + values[i-1])  

(若 j >= weights[i-1],否则直接继承 dp[i-1][j]

Python代码

python 复制代码
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 j >= weights[i-1]:
                dp[i][j] = max(dp[i-1][j], dp[i-1][j-weights[i-1]] + values[i-1])
            else:
                dp[i][j] = dp[i-1][j]
    return dp[n][capacity]
空间优化(一维数组)
python 复制代码
def knapsack_01_optimized(weights, values, capacity):
    dp = [0] * (capacity + 1)
    for i in range(len(weights)):
        for j in range(capacity, weights[i] - 1, -1):  # 逆向遍历
            dp[j] = max(dp[j], dp[j - weights[i]] + values[i])
    return dp[capacity]

完全背包问题

问题描述:与0-1背包类似,但每个物品可以选无限次。

状态转移方程

复制代码
dp[i][j] = max(dp[i-1][j], dp[i][j-weights[i-1]] + values[i-1])  

(注意与0-1背包的区别:第二项是 dp[i][...]

Python代码(空间优化版)

python 复制代码
def knapsack_unbounded(weights, values, capacity):
    dp = [0] * (capacity + 1)
    for i in range(len(weights)):
        for j in range(weights[i], capacity + 1):  # 正向遍历
            dp[j] = max(dp[j], dp[j - weights[i]] + values[i])
    return dp[capacity]

关键区别

  1. 遍历顺序

    • 0-1背包:内层循环逆向遍历(避免重复计算)。
    • 完全背包:内层循环正向遍历(允许重复选择)。
  2. 状态转移

    • 0-1背包依赖上一行 dp[i-1][...]
    • 完全背包依赖当前行 dp[i][...]

应用场景

  • 0-1背包:物品唯一性(如选/不选)。
  • 完全背包:物品无限供应(如硬币找零问题)。
相关推荐
森G1 分钟前
TypeScript 基础类型
开发语言·typescript
huipeng92636 分钟前
企业级微服务开发实战(一):项目启动与工程化设计
java·开发语言·spring boot·spring cloud·微服务·云原生·架构
爱吃土豆的马铃薯ㅤㅤㅤㅤㅤㅤㅤㅤㅤ1 小时前
java实现excel导入、下载模板方法
java·开发语言·excel
眠りたいです1 小时前
现代C++:C++14中的新语言特性和库特性
c语言·开发语言·c++
隔壁大炮1 小时前
MNE-Python 第9天学习笔记:源定位基础
python·eeg·mne·脑电数据处理
叶小鸡2 小时前
Java 篇-项目实战-AI 天机学堂(从 0 到 1)-day1
java·开发语言
Daydream.V3 小时前
Python Flask超全入门实战教程|从零基础到项目部署
大数据·python·flask
databook3 小时前
Manim物理模拟:别自己写欧拉了!
python·数学·动效
楼田莉子4 小时前
C++17新特性:__had_include/属性/求值顺序规则
开发语言·c++·后端
香蕉鼠片4 小时前
Python进阶学习
开发语言·python