社区讨论
10分dp萌新求助dalao
P1510精卫填海参与者 2已保存回复 1
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 1 条
- 当前快照
- 1 份
- 快照标识符
- @lo861qnn
- 此快照首次捕获于
- 2023/10/27 13:21 2 年前
- 此快照最后确认于
- 2023/10/27 13:21 2 年前
CPP
#include<bits/stdc++.h>
using namespace std;
int bag,n,c,w[10100],v[10100],dp[1001][7000];
int check(int index,int rest,int step)
{
if(dp[index][rest]!=-1)
return dp[index][rest];
int ans=0;
if(rest<0)
ans = step-1;
else
if(index==n+1)
ans = 0;
else{
int p1 = check(index+1,rest,step);
int p2=0;
int next=check(index+1,rest-w[index],step+1);
if(next!=step)
p2=next+v[index];
ans = step;
}
dp[index][rest] = ans;
return ans;
// cout<<step<<endl;
}
int main()
{
cin>>bag>>n>>c;
int sum=0,flag=0,summ=0;
for(int i=1;i<=n;i++)
{
cin>>w[i]>>v[i];
sum+=w[i];
if(v[i]<=c)
{
flag=1;
summ+=w[i];
}
}
if(sum<bag||(flag==0)||summ<bag)
cout<<"Impossible";
else cout<<check(1,bag,0);
return 0;
}
回复
共 1 条回复,欢迎继续交流。
正在加载回复...