10pts
查看原帖
10pts
1250875
sqrt_PI楼主2025/8/5 09:43
#include<bits/stdc++.h>
using namespace std;
int V[10005],u[10005],dp[10005];
int main(){
    int v,n,c;
    cin>>v>>n>>c;
    for(int i=1;i<=n;i++){
        cin>>V[i]>>u[i];
    }
    for(int i=1;i<=n;i++){
        for(int j=c;j>=u[i];j--){
            dp[j]=max(dp[j],dp[j-u[i]]+V[i]);
        }
    }
    for(int i=0;i<=c;i++){
        if(dp[i]>=v){
            cout<<v-dp[i];
            return 0;
        }
    }
    cout<<"Impossible";
    return 0;
}
2025/8/5 09:43
加载中...