介绍一下背包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背包:物品唯一性(如选/不选)。
  • 完全背包:物品无限供应(如硬币找零问题)。
相关推荐
Luminous.2 分钟前
C语言--day30
c语言·开发语言
码云骑士13 分钟前
32-慢查询排查全流程(下)-索引优化实战与最左前缀原则
python
何以解忧,唯有..20 分钟前
Go语言循环语句详解:for、range与循环控制
开发语言·算法·golang
謓泽28 分钟前
C语言不是语法,是通往机器的地图。
c语言·开发语言
云水一下30 分钟前
从零开始学 PHP 系列(一):PHP 的前世今生与开发环境搭建
开发语言·php
飞天狗11133 分钟前
零基础JavaWeb入门——第五课第二小节:九大内置对象 · 第2个:response(响应对象)
java·开发语言
DJ斯特拉34 分钟前
axios快速使用
开发语言·前端·javascript
xingpanvip1 小时前
星盘接口开发文档:本命盘接口指南
android·开发语言·css·php·lua
闵孚龙1 小时前
《PyTorch 深度修炼》Dataset 和 DataLoader:数据如何喂给模型
人工智能·pytorch·python
于先生吖1 小时前
教育类Java实战项目:在线错题整理平台分层架构设计与接口源码解析
java·开发语言