Pagini recente » Cod sursa (job #1046398) | Cod sursa (job #2878475) | Cod sursa (job #2746803) | Cod sursa (job #1817789) | Cod sursa (job #1503723)
#include <iostream>
#include <fstream>
using namespace std;
ifstream in("energii.in");
ofstream out("energii.out");
#define INF 20000
int e[1003],c[1003];
int mat[1003][5002];
int main()
{
int g,w,su=0,i,j;
in>>g>>w;
for(i=1;i<=g;i++)
{in>>e[i]>>c[i]; su+=e[i];}
if(su<w)out<<-1;
else{
for(i=1;i<=g;i++)
for(j=1;j<=su;j++)
mat[i][j]=INF;
for(i=1;i<=e[1];i++)
mat[1][i]=c[i];
for(i=2;i<=g;i++)
for(j=1;j<=su;j++)
mat[i][j]=min(mat[i-1][j],mat[i-1][j-e[i]]+c[i]);
out<<mat[g][w];
}
return 0;
}