思路

这是一个分组背包的模板题,套一下下面的板吧!
for 所有的组
----for k=体力 k>0
-------- for 这个组的操作
------------ dp递推式

代码

#include<bits/stdc++.h>
using namespace std;
const int maxn=1005;

int main(){
    ios::sync_with_stdio(0);
    cin.tie(0);cout.tie(0);
    int t,n,m,a[maxn],v[maxn][maxn],w[maxn][maxn],dp[maxn];
    cin>>t;
    while(t--){
        memset(dp,0,sizeof(dp));
        cin>>n>>m;
        for(int i=1;i<=n;i++){
            cin>>a[i];
            for(int j=1;j<=a[i];j++) cin>>v[i][j];
            for(int j=1;j<=a[i];j++) cin>>w[i][j];
        }
        for(int i=1;i<=n;i++){
            for(int k=m;k>=0;k--){
                for(int j=1;j<=a[i];j++){
                    if(k>=w[i][j]) dp[k]=max(dp[k],dp[k-w[i][j]]+v[i][j]);
                }
            }
        }
        cout<<dp[m]<<endl;
    }
    return 0;
}