【分组背包】

【分组背包】

推荐好文

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

给定 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;
}
相关推荐
放羊郎3 小时前
基于ORB-SLAM2算法的优化工作
人工智能·算法·计算机视觉
mask哥4 小时前
力扣算法java实现汇总整理(上)
java·算法·leetcode
袁雅倩19974 小时前
当吸尘器、筋膜枪都用上Type-C,供电方案该怎么选?浅谈PD取电芯片ECP5702的应用
c语言·开发语言·支持向量机·动态规划·推荐算法·最小二乘法·图搜索算法
如果'\'真能转义说4 小时前
OOXML 文档格式剖析:哈希、ZIP结构与识别
xml·算法·c#·哈希算法
梦梦代码精6 小时前
BuildingAI 上部署自定义工作流智能体:5 个实用技巧
大数据·人工智能·算法·开源软件
Zephyr_07 小时前
Leedcode算法题
java·算法
流年如夢7 小时前
栈和列队(LeetCode)
数据结构·算法·leetcode·链表·职场和发展
Hello.Reader8 小时前
算法基础(十)——分治思想把大问题拆成小问题
java·开发语言·算法
绛橘色的日落(。・∀・)ノ9 小时前
机器学习之评估与偏差方差分析
算法