Pagini recente » Cod sursa (job #1965114) | Cod sursa (job #2872618) | Cod sursa (job #2509858) | Cod sursa (job #428681) | Cod sursa (job #429584)
Cod sursa(job #429584)
#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<=16000;i++){
s[i]=99999999;
}
su=0;
for(i=1;i<=g;i++){
for(j=w;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>=w&&s[j+v[i].en]<s[w]){
s[w]=s[j+v[i].en];
}
}
}
for(i=1;i<=su;i++){
if(i>=w&&s[i]<min){
min=s[i];
}
}
if(s[w]==99999999){
printf("-1");
}else{
printf("%d\n",s[w]);
}
return 0;
}