Pagini recente » Cod sursa (job #2020880) | Cod sursa (job #2024384) | Monitorul de evaluare | Cod sursa (job #1472290) | Cod sursa (job #1278275)
#include <fstream>
#define INF 1000001
using namespace std;
ifstream fin("energii.in");
ofstream fout("energii.out");
int G[1002],W[1002],n,s,i,j,D[5002];
int main(){
fin>>n>>s;
for(i=1;i<=n;i++)
fin>>G[i]>>W[i];
for(i=1;i<=s;i++)
D[i]=INF;
for(i=1;i<=n;i++)
for(j=0;j<=s && j+G[i]<=s;j++)
if(D[j]!=INF)
if(D[j]+W[i]<D[j+G[i]] && j+G[i]<=s)
D[j+G[i]]=D[j]+W[i];
if(D[s]==INF)
fout<<'-1';
else
fout<<D[s];
fin.close();fout.close();
return 0;
}