01背包,完全背包,多重背包的二进制优化
#include <iostream>
#include<string.h>
#include<algorithm>
using namespace std;
const int N=1e6;
int f[N],n,m;
int v[N],w[N];
int main()
{
cin>>n>>m;
int cnt=0;
for(int i=1;i<=n;i++)
{
int a,b,c;
cin>>a>>b>>c;
if(c==-1)//01背包
{
for(int j=m;j>=a;j--)
f[j]=max(f[j],f[j-a]+b);
}
else if (c==0)
{
for(int j=a;j<=m;j++)
f[j]=max(f[j],f[j-a]+b);
}
else{
int k=1;
while(k<c)
{
cnt++;
v[cnt]=a*k;
w[cnt]=b*k;
c-=k;
k*=2;
}
if(c>0)
{
cnt++;
v[cnt]=a*c;
w[cnt]=b*c;
}
}
}
for(int i=1;i<=cnt;i++)
for(int j=m;j>=v[i];j--)
f[j]=max(f[j],f[j-v[i]]+w[i]);
cout<<f[m]<<endl;
return 0;
}