Cod sursa(job #2505946)
| Utilizator | Data | 7 decembrie 2019 12:04:51 | |
|---|---|---|---|
| Problema | Problema rucsacului | Scor | 100 |
| Compilator | cpp-64 | Status | done |
| Runda | Arhiva educationala | Marime | 0.67 kb |
#include <bits/stdc++.h>
using namespace std;
ifstream fin("rucsac.in");
ofstream fout("rucsac.out");
int N, G, k = 1;
int p[10001], g[10001], dp[2][10001];
int main()
{
fin >> N >> G;
for(int i = 1; i <= N; i++)
{
fin >> g[i] >> p[i];
}
for(int i = 1; i <= N; i++)
{
for(int j = 1; j <= G; j++)
{
if(j - g[i] >= 0)
{
dp[k][j] = max(dp[1-k][j], dp[1-k][j - g[i]] + p[i]);
}
else
{
dp[k][j] = dp[1-k][j];
}
}
k = 1 - k;
}
fout << dp[1-k][G];
return 0;
}
