【分组背包】

【分组背包】

推荐好文

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

给定 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;
}
相关推荐
李兆龙的博客2 小时前
从一到无穷大 #68 Agent Memory 全景:大模型智能体记忆机制的形态、动态与前沿
大数据·人工智能·算法
cwplh2 小时前
平衡树学习笔记
数据结构·笔记·学习·算法
wen__xvn2 小时前
天梯赛L2刷题(也就写写水题骗骗自己了)
算法
EllinY2 小时前
扩展欧几里得算法 exgcd 详解
c++·笔记·数学·算法·exgcd
AI科技星3 小时前
三维网格—素数对偶性及其严格证明(全域数学·统一基态演化版)
算法·数学建模·数据挖掘
诸葛务农3 小时前
光电对抗:多模复合制导烟雾干扰外场试验及仿真(4)
人工智能·算法·光电对抗
WolfGang0073213 小时前
代码随想录算法训练营 Day39 | 动态规划 part12
算法·动态规划
阿Y加油吧3 小时前
动态规划经典题解:最长递增子序列 & 乘积最大子数组
算法·动态规划·代理模式
f3iiish3 小时前
3783. 整数的镜像距离 力扣
算法·leetcode