#P45. 【模板】混合背包

    ID: 841 传统题 1000ms 256MiB 尝试: 0 已通过: 0 难度: 3 上传者: 标签>动态规划一本通在线评测DP01背包完全背包多重背包混合背包

【模板】混合背包

题目描述

一个旅行者有一个最多能装 MM 公斤的背包,现在有 nn 件物品,它们的重量分别是 W1W2...,WnW_1,W_2,...,W_n,它们的价值分别是 C1,C2,...,CnC_1,C_2,...,C_n。有的物品只可以取一次(01背包),有的物品可以取无限次(完全背包),有的物品可以取的次数有一个上限(多重背包)。求解将哪些物品装入背包可使这些物品的费用总和不超过背包容量,且价值总和最大。

输入格式

第一行:两个整数,MM(背包容量,M200M \le 200),NN(物品数量,N30N \le 30); 第 2N+12 \dots N+1 行:每行三个整数 Wi,Ci,PiW_i,C_i,P_i,前两个整数分别表示每个物品的重量、价值,第三个整数若为 00,则说明此物品可以购买无数件,若为其他数字,则为此物品可购买的最多件数(PiP_i)。

输出格式

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

样例 #1

样例输入 #1

10 3
2 1 0
3 3 1
4 5 4

样例输出 #1

11

样例解释 #1

最优选择为:选第一件物品 11 件(重量 22,价值 11)和第三件物品 22 件(重量 4×2=84 \times 2 = 8,价值 5×2=105 \times 2 = 10)。总重量为 2+8=102+8=10,总价值为 1+10=111+10=11,符合背包容量限制,且为可获得的最大价值。

数据范围与提示

对于 100%100\% 的数据,1M2001 \le M \le 2001N301 \le N \le 301Wi,Ci1001 \le W_i,C_i \le 1000Pi1000 \le P_i \le 100