Run ID | 作者 | 问题 | 语言 | 测评结果 | 分数 | 时间 | 内存 | 代码长度 | 提交时间 |
---|---|---|---|---|---|---|---|---|---|
142226 | 冼俊烨 | 分组背包 | C++ | 通过 | 100 | 1 MS | 1068 KB | 678 | 2024-04-06 17:32:13 |
#include <bits/stdc++.h> using namespace std; int m,n,p,K; int w[10001],c[10001],f[10001],stone[10001][1001]; int main() { scanf("%d%d",&m,&n); for(int i=1; i<=n; i++) { scanf("%d%d%d",&w[i],&c[i],&p); stone[p][++stone[p][0]]=i; K=max(K,p); //统计最多有多少组 } for(int k=1; k<=K; k++) //枚举组数 for(int j=m; j>=0; j--) //倒序枚举背包容量 for(int i=1; i<=stone[k][0]; i++) //枚举k组里的所有物品 if(w[stone[k][i]]<=j) //如果可以放 f[j]=max(f[j],f[j-w[stone[k][i]]]+c[stone[k][i]]); printf("%d\n",f[m]); }