Cod sursa(job #2729871)
Utilizator | isache bogdan bogdan62003 | Data | 25 martie 2021 15:26:05 |
---|---|---|---|
Problema | Problema rucsacului | Scor | 100 |
Compilator | cpp-64 | Status | done |
Runda | Arhiva educationala | Marime | 0.65 kb |
#include <bits/stdc++.h>
using namespace std;
ifstream fin("rucsac.in");
ofstream fout("rucsac.out");
int n, w[5001], p[5001], dp[2][10001], G, aux, u, v;
int main()
{
fin>>n>>G;
for(int i=1; i<=n; i++)
fin>>w[i]>>p[i];
u=0;
v=1;
for(int i=1; i<=n; i++)
{
for(int g=1; g<=G; g++)
{
dp[v][g]=dp[u][g]; ///nu iau obiectul i
if(g>=w[i]) ///incerc sa iau obiectul
{
aux=dp[u][g-w[i]]+p[i];
if(aux>dp[v][g])
dp[v][g]=aux;
}
}
u=1-u;
v=1-v;
}
fout<<dp[u][G];
}