Pagini recente » Cod sursa (job #2934726) | Cod sursa (job #2920033) | Cod sursa (job #236126) | Cod sursa (job #1948286) | Cod sursa (job #2361963)
#include <bits/stdc++.h>
#define f first
#define s second
using namespace std;
ifstream in("energii.in");
ofstream out("energii.out");
pair<int,int> a[1001];
int dp[1001][5001];
int main(){
int n,w,i,j,sum=0,sum2=0;
in>>n>>w;
for(i=1; i<=n; ++i){
in>>a[i].f>>a[i].s;
sum+=a[i].f;
sum2+=a[i].s;
}
if(sum<w){
out<<-1;
return 0;
}
for(i=1; i<=n; ++i){
for(j=sum; j>=w; --j){
dp[i][j]=dp[i-1][j];
if(sum-j>=a[i].f)
dp[i][j]=max(dp[i][j], dp[i-1][j+a[i].f]+a[i].s);
}
}
out<<sum2-dp[n][w];
return 0;
}