Pagini recente » Cod sursa (job #791480) | Cod sursa (job #124908) | Cod sursa (job #2855896) | Cod sursa (job #3247291) | Cod sursa (job #1428475)
#include <cstdio>
#include <algorithm>
using namespace std;
const int INF=1e9;
const int WMAX=5001;
int d[WMAX];
int main()
{
freopen("energii.in","r",stdin);
freopen("energii.out","w",stdout);
int G,W,i,e,c,last,j;
scanf("%d%d",&G,&W);
last=0;
for(i=1; i<=W; ++i)
d[i]=INF;
for(i=1; i<=G; ++i)
{
scanf("%d%d",&e,&c);
for(j=last; j>=0; --j)
if(d[j]!=INF)
if(j+e<=W)
{
if(d[j+e]>d[j]+c)
{
d[j+e]=d[j]+c;
if(j+e>last)
last=j+e;
}
}
else if(d[W]>d[j]+c)
{
d[W]=d[j]+c;
last=W;
}
}
if(d[W]==INF)
printf("-1");
else
printf("%d",d[W]);
}