You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

59 lines
1.4 KiB

2 years ago
#include <bits/stdc++.h>
using namespace std;
#define maxV 1000
int f[maxV], v;
/*
3.
1
nv
in[i]c[i]w[i]
使
2
nni ci wi
* */
void ZeroOnePack(int ci, int wi) {
for (int j = v; j >= 0; j--)
if (j >= ci)
f[j] = max(f[j], f[j - ci] + wi);
}
void CompletePack(int ci, int wi) {
for (int j = 0; j <= v; j++)
if (j >= ci)
f[j] = max(f[j], f[j - ci] + wi);
}
void MultiplePack(int ni, int ci, int wi) {
if (ni * ci >= v) {
CompletePack(ci, wi);
return;
}
int k = 1, amount = ni;
while (k < ni) {
ZeroOnePack(ci * k, wi * k);
amount -= k;
k *= 2;
}
ZeroOnePack(ci * amount, wi * amount);
}
int main(void) {
int cases, n, ni, ci, wi;
freopen("../3.txt", "r", stdin);
cin >> cases;
while (cases--) {
memset(f, 0, sizeof(f));
cin >> n >> v;
for (int i = 0; i < n; i++) {
cin >> ni >> ci >> wi;
MultiplePack(ni, ci, wi);
}
//for (int i = 0; i <= v; i++) cout << f[i] << " "; cout << endl;
cout << f[v] << endl;
}
return 0;
}