算法知识-背包dp

一.01背包

1.01背包模板题

T538725 【模板】01背包 - 洛谷

题意:总体积有V,每个物品都有w[i]价值,和v[i]体积,在不超过V时,让总价值最大

解决方案:

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

状态转移:

(1)不要i号物品,dp[i-1][j]

(2)要i号物品,dp[i-1][j-v[i]]+w[i]

上面两个值,二者取大

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

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

初始状态:

根据依赖,我们需要初始化第一行的格子,dp[0][j],那么选择0号物品,即为不选物品(因为物品编号从1开始),那么价值为0,则dp[0][j]=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];
}
相关推荐
ZPC82101 小时前
Linux 共享内存(shm)
算法
水木流年追梦1 小时前
大模型入门-应用篇2-RAG (检索增强生成):从原理到 Python 实战
开发语言·python·算法·prompt
数智工坊1 小时前
【连续动作空间算法2】TD3:DDPG的终极进化,根治连续控制中的函数近似误差
论文阅读·人工智能·算法·计算机视觉
洛水水1 小时前
【力扣100题】25. 搜索二维矩阵 II
算法·leetcode·矩阵
样例过了就是过了1 小时前
LeetCode热题100 多数元素
c++·算法·leetcode·贪心算法
白羊by1 小时前
YOLOv8 官方损失函数详解(按任务分类)
人工智能·深度学习·算法·yolo·分类
沪漂阿龙1 小时前
面试题:逻辑回归是什么?为什么用 Sigmoid、对数损失、最大似然、Softmax、多分类、类别不平衡一文讲透
人工智能·算法·机器学习·分类·逻辑回归
WL_Aurora2 小时前
备战蓝桥杯国赛【Day 9】
python·算法·蓝桥杯
洛水水2 小时前
【力扣100题】20.合并 K 个升序链表
算法·leetcode·链表