Pagini recente » Cod sursa (job #999995) | Cod sursa (job #2968531) | Cod sursa (job #1315629) | Cod sursa (job #2054321) | Cod sursa (job #2364403)
#include <cstdio>
#include <climits>
#include <iostream>
using namespace std;
int v[15005];
int main()
{
freopen("energii.in","r",stdin);
freopen("energii.out","w",stdout);
int n,g,i,j,x,y,l=0,aux,mx=0,ans=100000;
scanf("%d%d",&n,&g);
for(i=1;i<=n;++i)
{
scanf("%d%d",&x,&y);
aux=l;
for(j=l;j>=0;--j)
if(v[j]||j==0)
{
if(v[j+x]==0)
v[j+x]=100000;
v[j+x]=min(v[j+x],v[j]+y);
if(j+x<=g)
aux=max(aux,j+x);
mx=max(mx,j+x);
}
l=aux;
}
for(i=mx;i>=g;--i)
if(v[i])
ans=min(ans,v[i]);
if(ans==100000)
printf("-1");
else
printf("%d",ans);
return 0;
}