【分组背包】

【分组背包】

推荐好文

注:只是新手的笔记,慎看!!!欢迎大佬指错

给定 n 组物品,每组中有多件物品,但每组只能拿一件,求能拿的最大总价值

前置知识:01背包

从题目上看,分组背包和01背包区别在于每组中有多种物品,且只能拿一个

如此一来我们便可以想到在01背包的双重循环内,再填一个决策循环,事实上也只能这样写,时间复杂度难以优化

代码:

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
 
const int N = 110;
int n, m, v[N][N], w[N][N], s[N], f[N];
 
int main()
{
	cin >> n >> m;
 
	for (int i = 1; i <= n; i++)
	{
		cin >> s[i];
		for (int j = 0; j < s[i]; j++)
		{
			cin >> v[i][j] >> w[i][j];
		}
	}
	for (int i = 1; i <= n; ++i)
	{
		for (int j = m; j >= 0; --j)
		{
			for (int k = 0; k < s[i]; ++k)//决策循环
			{
				if (v[i][k] <= j)
					f[j] = max(f[j], f[j - v[i][k]] + w[i][k]);
			}
		}
	}
 
	cout << f[m] << endl;
 
	return 0;
}
相关推荐
kisshyshy16 小时前
🍦 雪糕、食堂、火车厢:三幅漫画吃透栈、队列与链表
javascript·算法
猿人谷1 天前
不只是 CPU 阈值:STAR 如何用 GAT + Transformer 做容器级自动扩缩容?
人工智能·算法
复杂网络1 天前
Stable Diffusion 视觉大模型微调技术深度调研
算法
复杂网络1 天前
基于 Stable Diffusion 架构的视觉大模型代表性工作与原理深度解析
算法
MrZhao4001 天前
Agent Loop 如何用 Hook 扩展:权限、日志与工具拦截
算法
MrZhao4001 天前
Agent 为什么需要 Skills:别把所有知识都塞进 system prompt
算法
JieE2122 天前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
JieE2123 天前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack204 天前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树4 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色