ACM模版
背包相关
const int MAXN =
101;
const int SIZE =
50001;
int dp[SIZE];
int volume[MAXN], value[MAXN], c[MAXN];
int n, v;
void ZeroOnepark(
int val,
int vol)
{
for (
int j = v ; j >= vol; j--)
{
dp[j] = max(dp[j], dp[j - vol] + val);
}
}
void Completepark(
int val,
int vol)
{
for (
int j = vol; j <= v; j++)
{
dp[j] = max(dp[j], dp[j - vol] + val);
}
}
void Multiplepark(
int val,
int vol,
int amount)
{
if (vol * amount >= v)
{
Completepark(val, vol);
}
else
{
int k =
1;
while (k < amount)
{
ZeroOnepark(k * val, k * vol);
amount -= k;
k <<=
1;
}
if (amount >
0)
{
ZeroOnepark(amount * val, amount * vol);
}
}
}
int main()
{
while (
cin >> n >> v)
{
for (
int i =
1 ; i <= n ; i++)
{
cin >> volume[i] >> value[i] >> c[i];
}
memset(dp,
0,
sizeof(dp));
for (
int i =
1; i <= n; i++)
{
Multiplepark(value[i], volume[i], c[i]);
}
cout << dp[v] << endl;
}
return 0;
}
转载请注明原文地址: https://ju.6miu.com/read-1300129.html