当前位置: 首页 > news >正文

【算法】动态规划专题⑨ —— 二维费用背包问题 python

目录

  • 前置知识
  • 进入正题
  • 实战演练


前置知识


【算法】动态规划专题⑤ —— 0-1背包问题 + 滚动数组优化 python


进入正题


二维费用背包问题

方法思路
二维费用背包问题在传统背包问题的基础上增加了第二个维度的限制(如重量)。
每个物品具有两种费用(体积和重量),背包在这两个维度上都有容量限制。
我们需要在不超过两种容量限制的前提下,选择物品使得总价值最大。

我们需要定义一个三维数组dp[i][j][k],表示从前i个物品中选择,重量不超过j、第二种费用不超过k时可以获得的最大价值。
不过,为了节省空间,通常可以将三维数组简化为二维数组,因为当前状态只依赖于前一个状态。


关键步骤

  1. 状态定义:使用二维数组 dp[j][k] 表示在体积为 j 和重量为 k 时的最大价值。
  2. 状态转移:对于每个物品,逆序遍历体积和重量,确保每个物品只被选取一次。

该方法通过动态规划高效地处理了二维费用限制,确保在合理的时间复杂度内找到最优解。时间复杂度为 O(N*V*W)


好了,实际运用的时候到了

实战演练


二维费用的背包问题 https://www.acwing.com/problem/content/8/


题目描述

N N N 件物品和一个容量是 V V V 的背包,背包能承受的最大重量是 M M M
每件物品只能用一次。体积是 v i v_i vi,重量是 m i m_i mi,价值是 w i w_i wi

求解将哪些物品装入背包,可使物品总体积不超过背包容量,总重量不超过背包可承受的最大重量,且价值总和最大。

输入格式

第一行三个整数, N , V , M N,V, M N,V,M,用空格隔开,分别表示物品件数、背包容积和背包可承受的最大重量。

接下来有 N N N 行,每行三个整数 v i , m i , w i v_i, m_i, w_i vi,mi,wi,用空格隔开,分别表示第 i i i 件物品的体积、重量和价值。

输出格式

输出一个整数,表示最大价值。

数据范围

0 < N ≤ 1000 0 \lt N \le 1000 0<N1000
0 < V , M ≤ 100 0 \lt V, M \le 100 0<V,M100
0 < v i , m i ≤ 100 0 \lt v_i, m_i \le 100 0<vi,mi100
0 < w i ≤ 1000 0 \lt w_i \le 1000 0<wi1000

输入样例

4 5 6
1 2 3
2 4 4
3 4 5
4 5 6

输出样例:

8

code:

n, v, m = map(int, input().split())
dp = [[0] * (m + 1) for _ in range(v + 1)]
for i in range(1, n + 1):vi, mi, wi = map(int, input().split())for j in range(v, vi - 1, -1):for k in range(m, mi - 1, -1):dp[j][k] = max(dp[j][k], dp[j - vi][k - mi] + wi)
print(dp[v][m])


END
如果有更多问题或需要进一步的帮助,可以在评论区留言讨论哦!
如果喜欢的话,请给博主点个关注 谢谢


http://www.mrgr.cn/news/90014.html

相关文章:

  • chromium-mojo
  • MATLAB | 基于Theil-Sen斜率和Mann-Kendall检验的栅格数据趋势分析
  • 2025年度Python最新整理的免费股票数据API接口
  • 排序合集之快排详解(二)
  • 蓝耘智算平台使用DeepSeek教程
  • Java之自定义注解
  • springboot简单应用
  • 【SQL教程|05】Mysql中Limit用法详解
  • 大疆前端开发面试题及参考答案(4万字长文)
  • 【R语言】卡方检验
  • HTML应用指南:利用GET请求获取全国盒马门店位置信息
  • 《Cherry Studio+DeepSeek+Whoosh:三剑合璧,打造高效AI知识库与全文搜索系统》
  • 【Spring】什么是Spring?
  • (六)C++的函数模板与类模板
  • camera系统之cameraprovider
  • 【CubeMX-HAL库】STM32F407—无刷电机学习笔记
  • 保研考研机试攻略:python笔记(4)
  • 【python】简单的flask做页面。一组字母组成的所有单词。这里的输入是一组字母,而输出是所有可能得字母组成的单词列表
  • 全程Kali linux---CTFshow misc入门(38-50)
  • 大数据学习之SparkSql
  • ZoomIt:提高演示效率的画板工具
  • leetcode_深度搜索和广度搜索 100. 相同的树
  • 【设计模式】【行为型模式】模板方法模式(Template Method)
  • (四)C++的类与动态内存分配
  • MySQL数据库(七)SQL 优化
  • C# Winform怎么设计串口,客户端和相机控件界面显示