Pagini recente » Cod sursa (job #123664) | Cod sursa (job #249745) | Cod sursa (job #2269849) | Cod sursa (job #112034) | Cod sursa (job #429564)
Cod sursa(job #429564)
#include<stdio.h>
int g,w,i,j,k,smax,aux,min=99999999,s[10000001],su;
struct gen{
int en,cost;
};
gen v[10001];
int main()
{
freopen("energii.in","r",stdin);
freopen("energii.out","w",stdout);
scanf("%d%d",&g,&w);
for(i=1;i<=g;i++){
scanf("%d%d",&v[i].en,&v[i].cost);
if(v[i].en>smax){
smax=v[i].en;
}
su+=v[i].en;
}
for(i=1;i<=su;i++){
s[i]=99999999;
}
su=0;
for(i=1;i<=g;i++){
for(j=su;j>=0;j--){
if(v[i].cost+s[j]<s[j+v[i].en])
{
s[j+v[i].en]=v[i].cost+s[j];
}
if(j+v[i].en>aux){
aux=j+v[i].en;
}
}
su=aux;
}
for(i=1;i<=su;i++){
if(i>=w&&s[i]<min){
min=s[i];
}
}
if(min==99999999){
printf("-1");
}else{
printf("%d\n",min);
}
return 0;
}