Pagini recente » Cod sursa (job #3253) | Borderou de evaluare (job #520023) | Cod sursa (job #416143) | Cod sursa (job #2739763) | Cod sursa (job #1200934)
#include<iostream>
#include<fstream>
using namespace std;
ifstream f("energii.in");
ofstream g("energii.out");
int N,W,i,j,t;
int e[1002],c[1002];
int a[2][5002];
int main()
{
f>>N>>W;
for (i=1;i<=N;i++)
{f>>e[i]>>c[i];t+=e[i];}
if (t<W)
g<<-1;
else
{
for (i=0;i<2;i++)
{
for (j=1;j<=W;j++)
{
a[i][j]=350000;
}
}
for (i=1;i<=N;i++)
{
for (j=1;j<=W;j++)
{
if (e[i]>=j)
a[1][j]=min(a[0][j],c[i]);
else
a[1][j]=min(a[0][j],a[0][j-e[i]]+c[i]);
}
}
for (j=0;j<=W;j++)
a[0][j]=a[1][j];
/*for (i=1;i<=N;i++)
{
for (j=1;j<=W;j++)
{
cout<<a[i][j]<<' ';
}
cout<<'\n';
}*/
g<<a[1][W]<<'\n';
}
f.close();g.close();
return 0;
}