社区讨论
多重背包超时30,大佬求救
P1776宝物筛选参与者 2已保存回复 2
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 2 条
- 当前快照
- 1 份
- 快照标识符
- @mi6hoz2x
- 此快照首次捕获于
- 2025/11/20 05:03 4 个月前
- 此快照最后确认于
- 2025/11/20 05:03 4 个月前
CPP
#include<stdio.h>
int max(int a,int b)
{
if(a>b)
return a;
else
return b;
}
int main()
{
int k,m,n,p[100001],v[100001],w[100001],i,j,f[100001]={0};
scanf("%d %d",&n,&m);
for(i=1;i<=n;i++)
{
scanf("%d %d %d",&v[i],&w[i],&p[i]);
for(k=1;k<=p[i];k++)
for(j=m;j>=w[i];j--)
f[j]=max(f[j],f[j-w[i]]+v[i]);
}
printf("%d\n",f[m]);
return 0;
}
回复
共 2 条回复,欢迎继续交流。
正在加载回复...