Run ID | 作者 | 问题 | 语言 | 测评结果 | 分数 | 时间 | 内存 | 代码长度 | 提交时间 |
---|---|---|---|---|---|---|---|---|---|
147548 | 吴悠 | FATE | C++ | 通过 | 100 | 0 MS | 288 KB | 567 | 2024-05-18 15:47:32 |
#include<iostream> #include<cstring> using namespace std; int a[101],b[101]; int dp[101][101]; int main(){ int n,m,k,s; while(cin>>n>>m>>k>>s){ memset(dp,0,sizeof(dp)); for(int i=1;i<=k;i++){ cin>>a[i]>>b[i]; } for(int i=1;i<=k;i++){ for(int u=1;u<=s;u++){ for(int v=b[i];v<=m;v++){ dp[u][v]=max(dp[u][v],dp[u-1][v-b[i]]+a[i]); } } } int f=-1; for(int u=0;u<=m;u++){ for(int v=1;v<=s;v++){ if(dp[v][u]>=n){ f=m-u; u=m+1; break; } } } cout<<f<<endl; } return 0; }