#3275. 混合背包
混合背包
问题描述
有 ( N ) 种物品和一个容量是 ( V ) 的背包。物品分为三类:
- 01背包:只能用1次(( s_i = -1 ));
- 完全背包:可以用无限次(( s_i = 0 ));
- 多重背包:最多只能用 ( s_i ) 次(( s_i > 0 ))。
每种物品的体积是 ( v_i ),价值是 ( w_i )。求解将哪些物品装入背包,可使物品体积总和不超过背包容量,且总价值最大。
输入格式
第一行两个整数 ( N )、( V ),用空格隔开,分别表示物品种数和背包容积。
接下来 ( N ) 行,每行三个整数 ( v_i )、( w_i )、( s_i ),用空格隔开:
- ( s_i = -1 ):表示第 ( i ) 种物品只能用1次;
- ( s_i = 0 ):表示第 ( i ) 种物品可以用无限次;
- ( s_i > 0 ):表示第 ( i ) 种物品可以使用 ( s_i ) 次。
输出格式
输出一个整数,表示最大价值。
数据范围
[0 < N, V < 1000]
[0 < v_i, w_i < 1000]
[-1 \leq s_i < 1000]
输入样例
4 5
1 2 -1
2 4 1
3 4 0
4 5 2
输出样例
8