Pagini recente » Cod sursa (job #915820) | Cod sursa (job #2444080) | Cod sursa (job #3234039) | Cod sursa (job #2492833) | Cod sursa (job #1887703)
/* Se da o multime formata din N obiecte, fiecare fiind caracterizat de o greutate si un profit.
Sa se gaseasca o submultime de obiecte astfel incat suma profiturilor lor sa fie maxima,
iar suma greutatilor lor sa nu depaseasca o valoare greutate. */
// O(N*G)
#include <fstream>
using namespace std;
ifstream f("rucsac.in");
ofstream g("rucsac.out");
int n,greutate,gr[5050],pr[5050],d[500][500];
int main()
{
f>>n>>greutate;
for (int i=1; i<=n; ++i) f>>gr[i]>>pr[i];
for (int i=1; i<=n; ++i)
{
for (int j=1; j<=greutate; ++j)
{
d[i][j]=d[i-1][j];
// il sutesc pe i daca pot, si daca se merita
if (gr[i]<=j) d[i][j]=max(d[i][j], d[i-1][j-gr[i]]+pr[i]);
}
}
g<<d[n][greutate]<<'\n';
f.close();
g.close();
return 0;
}