Mai intai trebuie sa te autentifici.
Cod sursa(job #819740)
Utilizator | Data | 19 noiembrie 2012 17:42:09 | |
---|---|---|---|
Problema | Problema rucsacului | Scor | 0 |
Compilator | cpp | Status | done |
Runda | Arhiva educationala | Marime | 0.84 kb |
#include <fstream>
using namespace std;
ifstream fin("rucsac.in");
ofstream fout("rucsac.out");
int n,g;
int gr[5001],p[5001],cmax[5001],uz[5001][5001];
void citire();
void pd();
void afisare();
int main()
{
citire();
pd();
afisare();
fout.close();
return 0;
}
void citire()
{
int i;
fin>>n>>g;
for(i=1;i<=n;i++)
fin>>gr[i]>>p[i];
}
void pd()
{
int i,j,k,s;
for(k=1;k<=g;k++) cmax[k]=-1;
for(s=1;s<=g;s++)
for(i=1;i<=n;i++)
if(gr[i]<=s && uz[s-gr[i]][i]==0)
if(p[i]+cmax[s-gr[i]]>cmax[s])
{
cmax[s]=p[i]+cmax[s-gr[i]];
for(j=1;j<=n;j++)
uz[s][j]=uz[s-gr[i]][j];
uz[s][i]=1;
}
}
void afisare()
{
fout<<cmax[g];
}