【分组背包】

【分组背包】

推荐好文

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

给定 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;
}
相关推荐
weixin_468466852 分钟前
通义千问核心能力与实战表现深度评测
人工智能·深度学习·算法·ai·大模型
菜菜的顾清寒6 分钟前
力扣HOT100(48)图论-腐烂的橘子
算法·leetcode·图论
Ulyanov14 分钟前
深入QML滑块与进度控制:构建动态数据可视化界面:QML+PySide6现代开发入门(六)
开发语言·python·算法·ui·信息可视化·雷达电子对抗仿真
星马梦缘14 分钟前
ACM笔记 学习版本
数据结构·c++·算法
CQU_JIAKE16 分钟前
6.1【A】
算法
wayz1119 分钟前
Momentum:CTI(相关趋势指标)技术指标详解
算法·金融·数据分析·量化交易·特征工程
fengxin_rou21 分钟前
【滑动窗口与前缀和算法实战】:LeetCode560.438 高频题深度解析
java·算法·leetcode
Dillon Dong23 分钟前
【风电控制】FPGA vs DSP 在ADC采样中的选择——从架构差异到工程实践
算法·变流器·风电控制·dfig
科研小白_23 分钟前
【第九期:MATLAB点云处理基础】基于 Alpha Shapes 的边缘点提取
算法
sali-tec27 分钟前
C# 基于OpenCv的视觉工作流-章80-长短脚
图像处理·人工智能·opencv·算法·计算机视觉