分组背包
#include<iostream>
#include<algorithm>
using namespace std;
const int N = 110;
int dp[N][N];
int n,m;
int s[N];
int w[N][N];//体积
int v[N][N];//价值
int main()
{
cin>>n>>m;
for(int i=1;i<=n;i++)
{
cin>>s[i];
for(int j=1;j<=s[i];j++)
{
cin>>w[i][j]>>v[i][j];
}
}
for(int i=1;i<=n;i++)
{
for(int j=0;j<=m;j++)
{
dp[i][j]=dp[i-1][j];// 不选第i组的物品
for(int k=1;k<=s[i];k++)
{
if(j>=w[i][k])
{
dp[i][j]=max(dp[i][j],dp[i-1][j-w[i][k]]+v[i][k]);
}
}
}
}
cout<<dp[n][m];
return 0;
}
优化:
#include<iostream>
#include<algorithm>
using namespace std;
const int N = 110;
int dp[N];
int n,m;
int s[N];
int w[N][N];//体积
int v[N][N];//价值
int main()
{
cin>>n>>m;
for(int i=1;i<=n;i++)
{
cin>>s[i];
for(int j=1;j<=s[i];j++)
{
cin>>w[i][j]>>v[i][j];
}
}
for(int i=1;i<=n;i++)
{
for(int j=m;j>=0;j--)
{
for(int k=1;k<=s[i];k++)
{
if(j>=w[i][k])
{
dp[j]=max(dp[j],dp[j-w[i][k]]+v[i][k]);
}
}
}
}
cout<<dp[m];
return 0;
}