Cod sursa(job #1250507)
| Utilizator | Data | 28 octombrie 2014 11:27:07 | |
|---|---|---|---|
| Problema | Problema rucsacului | Scor | 35 |
| Compilator | cpp | Status | done |
| Runda | Arhiva educationala | Marime | 0.58 kb |
#include <iostream>
#include <fstream>
using namespace std;
ifstream fin("rucsac.in");
ofstream fout("rucsac.out");
#define MAX 5005
#define MAX1 10001
int a[MAX][MAX1], p[MAX], w[MAX];
int main()
{
int n,g;
fin >> n >> g;
for(int i = 1; i<=n; i++)
fin >> w[i] >> p[i];
for(int i = 1; i<=n; i++)
for(int j = 1; j<=g; j++)
{
if(j-w[i]>=0)
a[i][j] = max(a[i-1][j-w[i]]+p[i], a[i-1][j]);
else
a[i][j] = a[i-1][j];
}
fout << a[n][g] << "\n";
return 0;
}
