#P64. 【模板】分组背包

【模板】分组背包

题目描述

一个旅行者有一个最多能装 VV 公斤的背包,现在有 nn 件物品,它们的重量分别是 W1,W2,,WnW_1, W_2, \dots, W_n,它们的价值分别为 C1,C2,,CnC_1, C_2, \dots, C_n。这些物品被划分为若干组,每组中的物品互相冲突,最多选一件。求解将哪些物品装入背包可使这些物品的费用总和不超过背包容量,且价值总和最大。

输入格式

第一行三个整数 V,N,TV, N, T,分别表示背包容量、物品数量和最大组号。

接下来 NN 行,每行三个整数 Wi,Ci,PW_i, C_i, P,分别表示第 ii 件物品的重量、价值和所属组号。

输出格式

一行一个整数,表示最大总价值。

样例

10 6 3
2 1 1
3 3 1
4 8 2
6 9 2
2 8 3
3 9 3
20

提示

样例解释

背包总容量为 1010,最优选择为:从第 11 组选择重量 33、价值 33 的物品,第 22 组选择重量 44、价值 88 的物品,第 33 组选择重量 33、价值 99 的物品。总重量为 3+4+3=103+4+3=10,总价值为 3+8+9=203+8+9=20,符合背包容量限制,且为可获得的最大价值。

数据范围

  • 1V2001 \le V \le 200
  • 1N301 \le N \le 30
  • 1T101 \le T \le 10
  • 1Wi,Ci1001 \le W_i, C_i \le 100
  • 每组至少有一件物品,组号 PP 满足 1PT1 \le P \le T