Pagini recente » Cod sursa (job #197026) | Cod sursa (job #297309) | Cod sursa (job #300791) | Cod sursa (job #1000627) | Cod sursa (job #2315194)
#include <iostream>
#include <fstream>
#include <vector>
#include <algorithm>
using namespace std;
ifstream f("rucsac.in");
ofstream g("rucsac.out");
struct obiect
{
int c, g;
};
int n, G;
vector <obiect> o;
vector <int> d;
vector <int> linie; //linie precedenta in dinamica
void citire()
{
f >> n >> G;
o.resize(n + 3);
d.resize(G + 3);
linie.resize(G + 3);
int i;
for (i = 1; i <= n; i++)
{
f >> o[i].g >> o[i].c;
}
f.close();
}
int main()
{
citire();
int i, j;
for (i =0 ; i <= n; i++)
{
for (j = 0; j <= G; j++)
{
if (j >=o[i].g)
d[j] = max(linie[j], linie[j - o[i].g] + o[i].c);
else
d[j] =linie[j];
//g << d[j] << " ";
}
linie = d;
//g << "\n";
}
g << d[G];
g.close();
return 0;
}