蓝桥杯刷题第二天——背包问题

题目描述

有N件物品和一个容量是V的背包。每件物品只能使用一次。第i件物品的体积是Vi价值是Wi。

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

输出最大价值。

输入格式

第一行两个整数,N,V,用空格隔开,分别表示物品数量和背包容积。

接下来有N行,每行两个整数,W,用空格隔开,分别表示第件物品的体积和价值。

输出格式

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

数据范围

0< N,V≤ 1000

0<v,W≤1000

解题思路

此题可用动态规划来解决。

1.首先定义一个二维数组组dpij,表示前i个物品放入容量为j的背包中能获得的最大价值。

2.状态转移方程为:dpij=max(dpi-1j,dpi-1j-v\[i]+wi],其中vi 和 wi 分别是第i个物品的体积和价值。这个方程的含义是,对于第i个物品,有两种选择:不放入背包(价值为dpi-1j),或者放入背包(价值为dpi-1j-v\[i]+wi),取两者中的较大值。

3.边界条件:当i=或=时,dpi[j]=,即没有物品或者背包容量为0时,最大价值为 0。

代码示例

复制代码
N, V = map(int, input().split())
dp = [[0] * (V + 1) for _ in range(N + 1)]
for i in range(1, N + 1):
    v, w = map(int, input().split())
    for j in range(1, V + 1):
        dp[i][j] = dp[i - 1][j]
        if j >= v:
            dp[i][j] = max(dp[i][j], dp[i - 1][j - v] + w)
print(dp[N][V])

结果展示

相关推荐
lqjun08273 分钟前
PyTorch梯度计算
人工智能·pytorch·python
词元Max4 分钟前
3.1 Agent开发需要懂多少数学?
人工智能·python
许彰午5 分钟前
06_Java面向对象入门
java·开发语言·python
ZHW_AI课题组5 分钟前
使用 Rectified Flow 和 Diffusion Transformer实现 MNIST 手写数字图像生成
人工智能·python·机器学习
Royzst9 分钟前
一、IO 概述
开发语言·python
Omics Pro10 分钟前
P4医学4大支柱需绑定4大数字技术才可落地
人工智能·python·算法·机器学习·plotly
海鸥-w11 分钟前
前端学习python第三天笔记整理(list 列表,str字符串,tuple元组,set集合,dect,函数,类型注解)
前端·python·学习
机器学习是魔鬼18 分钟前
在矩池云上开箱即用Energy Forecasting:能源电力电价预测实战指南
人工智能·python·机器学习
想要成为糕糕手19 分钟前
从Python基础到LLM接口实战:在Notebook上实现AI自动生成亚马逊电商文案
python·openai
郝学胜-神的一滴23 分钟前
力扣 144:二叉树前序遍历的优雅实现
java·数据结构·c++·python·算法·leetcode·职场和发展