python|背包问题

news/2025/3/16 16:18:44/文章来源:https://www.cnblogs.com/luminescence/p/18770319

问题描述

有n件物品,有容量为c的背包
每件物品占的容量为\(\omega_{i}\) ;价值为\(v_i\)
问在容量限制下怎样选择才能带走最大价值的物品
根据物品的选择,还可以分为以下几种类型:
1.0-1背包问题
2.完全背包问题
3.多重背包问题
4.混合背包问题

一、.0-1背包问题

基础递归解决

时间复杂度为 O(2ⁿ)
每个物品选择或不选择,返回两个选择中最大价值

def ks_recursion(n , c , weights , values):if n == 0 or capacity == 0:return 0if weights[n-1] > capacity:return knapsack_recursive(weights, values, capacity, n-1)not_take = knapsack_recursive(weights, values, capacity, n-1)take = knapsack_recursive(weights, values, capacity - weights[n-1], n-1) + values[n-1]return max(not_take, take)

记忆递归

通过缓存中间结果,将时间复杂度优化为 O(n*c)
字典记录已经存在的计算结果,避免重复计算同一子问题

def ks_recursion_memory(n,c,w:list,v:list,memo:dict):if n <0 or c <=0:#return 0if (n,c) in memo:return memo[(n,c)]no_taken = ks_loop(n-1,c,w,v,memo)#take = 0#if c >= w[n]:take = ks_loop(n-1,c-w[n],w,v,memo) + v[n]#memo[(n,c)] = max(take,no_taken)return memo[(n,c)]

二维数组

复杂度:O(n * c)
对每个物品 i 和每个容量 w:
若当前物品重量 > 剩余容量:无法选择该物品,继承前 i-1 个物品的结果。

dp[i][w] = dp[i-1][w]

若当前物品重量 ≤ 剩余容量:决策选或不选该物品,取最大价值。

dp[i][w] = max(dp[i-1][w],  dp[i-1][w - weights[i-1]] + values[i-1]  
)

最终结果在dp[n][c]

def ks_double_dim(n, c, w, v):dp = [[0] * (c + 1) for _ in range(n + 1)]for i in range(1, n + 1):  # i:每个物品for ca in range(1, c + 1):  # c:每个容量if w[i - 1] > ca:dp[i][ca] = dp[i - 1][ca]else:dp[i][ca] = max(dp[i - 1][ca], dp[i - 1][ca - w[i - 1]] + v[i - 1])##return dp[n][c]

一维数组

def ks_one(n,c,w,v):dp = [0]*(c+1)for i in range(n):for ca in range(c,w[i]-1,-1):dp[ca] = max(dp[ca],dp[ca-w[i]]+v[i])return dp[c]

二、完全背包问题

三、多重背包问题

四、混合背包问题

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/899834.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

第二章练习题

2.1 点击查看代码 TempStr = input("请输入带有符号的温度值:") if isinstance(TempStr, str) and TempStr[-1] in [F, f]:C = int((float(TempStr[0:-1]) - 32) / 1.8)print(f"转换后的温度是{C}C") elif isinstance(TempStr, str) and TempStr[-1] in […

DBeaver Ultimate Edtion 25.0 Multilingual (macOS, Linux, Windows) - 通用数据库工具

DBeaver Ultimate Edtion 25.0 Multilingual (macOS, Linux, Windows) - 通用数据库工具DBeaver Ultimate Edtion 25.0 Multilingual (macOS, Linux, Windows) - 通用数据库工具 One tool for all data sources 请访问原文链接:https://sysin.org/blog/dbeaver/ 查看最新版。原…

book_77_78作业

第2章程序练习题 2.1改造温度转换的输入(不会) 2.2汇率转换 2.3重量转换 2.4彩色蟒蛇 2.5等边三角形 2.6叠加等边三角形 2.7六角形 2.8正方形螺旋

[I.2]个人作业:软件案例分析

项目 内容这个作业属于哪个课程 2025春季软件工程(罗杰、任健)这个作业的要求在哪里 [I.2]个人作业:软件案例分析我在这个课程的目标是 在PSP中精进个人代码技术,在TSP中提高团队合作凝聚力这个作业在哪个具体方面帮助我实现目标 分析市场上的软件案例,全面地了解软件工程的…

Tailscale subnet-on-android

前言啊哈,前段时间提了个issue,然后开发者那边回复了 再过了一段事件,合并了。Jan 17合并的,Feb 4发布的,那我倒要看看有没有新东西。不错不错,新功能加上了。 subnet有什么用 有人要问了,你安卓又不是路由器,搞个subnet干啥? 但是安卓可以开热点啊,尤其是在外面的网…

根据索引进行MySQL查询的简单优化

查询优化SQL让SQL尽量可以命中索引,可以提示查询的效率(但是数据库如果不走索引的速度较快,就不会去走索引)最左匹配法则由于联合索引中包括了多个列,那么对于这多个列的匹配就有一定的规则,就是最左匹配法则, 在使用联合索引时,必须满足从左边开始匹配索引列。假设现在…

FastAPI依赖注入:参数共享与逻辑复用

扫描二维码关注或者微信搜一搜:编程智域 前端至全栈交流与成长第一章:依赖注入核心原理 1.1 依赖树构建机制 from fastapi import Dependsdef auth_service():return OAuth2Scheme()def db_conn(auth: dict = Depends(auth_service)):return Database(creds=auth)@app.get(&q…

洛谷-P1449 后缀表达式

重操旧业~ 本菜鸡看到题就只会想到数组,但后来发现不可行,出去俩元素,还得进来一个元素,不好调o(╥﹏╥)o emm...但还是有所收获的,2转2,利用2-0,而不是直接强制int转换哦 同时也发现被题中举的例子迷惑了,数字可不一定是个位数! 1、此题采用栈和二叉树的后序遍历思想(…

DQL(查询语句)

简单查询 查询一个字段 select 字段名 from 表名; 查询多个字段 select 字段名1,字段名2,...,字段名 from 表名; 查询全部字段 ①在查询多个字段中,将所有的字段名写入 ②select * from 表名;————效率低,可读性差,因为将星号转化为所有字段名需要耗费一定时间,所…

PTA

​ 题目描述 小轿车中有一个系统随时监测四个车轮的胎压,如果四轮胎压不是很平衡,则可能对行车造成严重的影响。让我们把四个车轮 —— 左前轮、右前轮、右后轮、左后轮 —— 顺次编号为 1、2、3、4。本题就请你编写一个监测程序,随时监测四轮的胎压,并给出正确的报警信息。…

第二章

TempStr = input("请输入带有符号的温度值:") if isinstance(TempStr, str) and TempStr[-1] in [F, f]:C = int((float(TempStr[0:-1]) - 32) / 1.8)print(f"转换后的温度是{C}C") elif isinstance(TempStr, str) and TempStr[-1] in [C, c]:F = int(1.8…

window11家庭版 WSL上安装CentOS7

环境 Windows11家庭版 1. 安装WSL配置 1.1 Win命令模式开启虚拟化步骤点击查看代码 # 启用适用于 Linux 的 Windows 子系统:打开powershell并输入: dism.exe /online /enable-feature /featurename:Microsoft-Windows-Subsystem-Linux /all /norestart# 启用虚拟化:以管理员打…