Pagini recente » Istoria paginii runda/abcdefghijklmnop | Cod sursa (job #2354597) | Cod sursa (job #965053) | Cod sursa (job #1332801) | Cod sursa (job #2437019)
#include <fstream>
using namespace std;
int dp[5001][10001], g[5001], c[5001];
int G, n, i, j, sol;
int main()
{
ifstream fin("rucsac.in");
ofstream fout("rucsac.out");
fin >> n >> G;
for(i = 1; i <= n; i ++)
fin >> g[i] >> c[i];
// Dinamica dp[i][j] - profitul maxim pe care-l putem obtine adaugand o submultime a
// primelor i obiecte, insumand greutatea j
for(i = 1; i <= n; i ++)
for(j = 0; j <= G; j ++)
{
// Mai intai nu punem obiectul i.
dp[i][j] = dp[i - 1][j];
// Daca acest lucru duce la o solutie curenta mai buna, adaugam obiectul i la o
// solutie anterioara.
if(g[i] <= j)
dp[i][j] = max(dp[i][j], dp[i - 1][j - g[i]] + c[i]);
}
// Solutia se va afla in statea dp[n][G]
sol = dp[n][G];
fout << sol;
return 0;
}