Pagini recente » Cod sursa (job #2703519) | Cod sursa (job #2397214) | Cod sursa (job #262895) | Cod sursa (job #2849186) | Cod sursa (job #1481004)
//http://www.infoarena.ro/problema/energii
#include <iostream>
#include <fstream>
using namespace std;
ifstream in("energii.in");
ofstream out("energii.out");
int e[2000],c[2000];
int g[1000000];
int n;
int main()
{ int i,j,w,s=0,m=0,st,dr,med;
in>>n;
in>>w;
for(i=1;i<=n;i++)
{in>>e[i]>>c[i];
s=s+e[i];
m=m+c[i];}
if(s<w)out<<-1;
else
{for(i=1;i<=n;i++)
for(j=m;j>=0;j--)
g[j+c[i]]=max(g[j+c[i]], g[j]+e[i]);
st=0;
dr=m;
while(st<dr)
{
med=(st+dr)/2;
if(g[med]>=w) dr=med-1;
if(g[med]<w)st=med+1;
}
out<<st;
}
return 0;
}