算法知识-背包dp

一.01背包

1.01背包模板题

T538725 【模板】01背包 - 洛谷

题意:总体积有V,每个物品都有wi价值,和vi体积,在不超过V时,让总价值最大

解决方案:

状态:dpij表示1到i物品自由选择,容量不超过j的情况下的最大价值

状态转移:

(1)不要i号物品,dpi-1j

(2)要i号物品,dpi-1j-v\[i]+wi

上面两个值,二者取大

通过观察状态转移方程,我们发现,每个格子依赖它的上面的格子,和它的上面左边的格子

所以我们的遍历顺序为从上往下,从左往右

初始状态:

根据依赖,我们需要初始化第一行的格子,dp0j,那么选择0号物品,即为不选物品(因为物品编号从1开始),那么价值为0,则dp0j=0;

cpp 复制代码
int f1(vector<int>& w, vector<int>& v,int V,int n) {
	vector<vector<int>>dp(n + 1, vector<int>(V + 1, 0));
	//初始状态dp[0][j]=0

	//dp[i][j]:1-i号物品任意选择,容量不超过j的最大价值
	for (int i = 1; i <= n; i++) {
		for (int j = 0; j <= V; j++) {
			//不要i号物品
			dp[i][j] = dp[i - 1][j];
			//选择i号物品
			if (j - v[i] >= 0) {
				dp[i][j] = max(dp[i][j], dp[i - 1][j - v[i]] + w[i]);
			}
		}
	}

	return dp[n][V];
}

状态压缩:

由于我们发现,每个格子依赖,上方,和左上方,所以我们只需要从上往下,从右往左更新

cpp 复制代码
int f2(vector<int>& w, vector<int>& v, int V, int n) {
    vector<int>dp(V + 1, 0);
	//初始状态dp[0][j]=0
	//dp[i][j]:1-i号物品任意选择,容量不超过j的最大价值
	for (int i = 1; i <= n; i++) {
		for (int j = V; j >=0; j--) {
			//不要i号物品
			//选择i号物品
			if (j - v[i] >= 0) {
				dp[j] = max(dp[j], dp[j - v[i]] + w[i]);
			}
		}
	}

	return dp[V];
}
相关推荐
杨充2 分钟前
1.3 浮点型数据设计灵魂
开发语言·python·算法
妄想出头的工业炼药师33 分钟前
GS slam mono
算法·开源
_日拱一卒1 小时前
LeetCode:207课程表
java·数据结构·算法·leetcode·职场和发展
用户987409238873 小时前
llamafactory 0.6.3 没有 llamafactory-cli
算法
计算机安禾3 小时前
【算法分析与设计】第26篇:参数化算法与固定参数可解性理论
大数据·人工智能·算法·机器学习·剪枝
AI科技星4 小时前
基于**v=c(空间光速螺旋运动)唯一第一性原理**重新完整求导证明
人工智能·线性代数·算法·机器学习·架构·概率论·学习方法
风筝在晴天搁浅4 小时前
美团 LeetCode 692.前K个高频单词
算法·leetcode·职场和发展
地平线开发者5 小时前
量化训练时 fusebn/withbn 简介
算法·自动驾驶
不做无法实现的梦~5 小时前
MAVLink 协议教程
linux·stm32·嵌入式硬件·算法
墨白曦煜5 小时前
算法实战笔记:剥开回溯算法的外衣——从通用模板到高阶去重(八)
笔记·算法