Pagini recente » Cod sursa (job #609221) | Cod sursa (job #577457) | Cod sursa (job #2900452) | Cod sursa (job #3144439) | Cod sursa (job #2125070)
#include<bits/stdc++.h>
using namespace std;
int g,w,ss;
int e[1100],c[1100],d[1100][5100];
int main(){
ifstream cin("energii.in");
ofstream cout("energii.out");
cin>>g>>w;
for(int i=1;i<=g;i++){
cin>>e[i]>>c[i];
}
for(int j=0;j<=w;j++)
d[0][j]=20000;
for(int i=1;i<=g;i++){
ss+=e[i];
for(int j=0,k=ss+1;j<=ss;j++,k++){
d[i][k]=20000;
if(j>e[i]) d[i][j]=min(d[i-1][j],d[i-1][j-e[i]]+c[i]);
else d[i][j]=min(d[i-1][j],c[i]);
}
}
//for(int i=1;i<=g;i++){
//for(int j=1;j<=w;j++)
// cout<<d[i][j]<<" ";
// cout<<'\n';
//}
if(ss>=w) cout<<d[g][w]; else cout<<"-1";
return 0;
}