Mai intai trebuie sa te autentifici.
Cod sursa(job #2254959)
| Utilizator | Data | 6 octombrie 2018 11:39:14 | |
|---|---|---|---|
| Problema | Problema rucsacului | Scor | 25 |
| Compilator | cpp | Status | done |
| Runda | Arhiva educationala | Marime | 0.57 kb |
#include <fstream>
#include <algorithm>
#define Nmax 10010
using namespace std;
int dp[5010][Nmax], 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];
for(i = 1; i <= n; i ++)
for(j = 0; j <= G; j ++)
{
dp[i][j] = dp[i - 1][j];
if(g[i] <= j)
dp[i][j] = max(dp[i][j], dp[i - 1][j - g[i]] + c[i]);
}
sol = dp[n][G];
fout << sol;
return 0;
}
