Cod sursa(job #1371597)
Utilizator | Data | 3 martie 2015 22:45:01 | |
---|---|---|---|
Problema | Energii | Scor | 0 |
Compilator | cpp | Status | done |
Runda | Arhiva de probleme | Marime | 0.52 kb |
#include <iostream>
#include <fstream>
using namespace std;
ifstream f("energii.in");
ofstream u("energii.out");
int w[10000],p[10000];
int o[100000],n,g,i,j,a=ULLONG_MAX;
int main()
{
f>>n>>g;
for (i=1;i<=n;i++) f>>w[i]>>p[i];
o[0]=0;
int sol=0;
for (i=1;i<=n;i++)
for (j=g-w[i];j>=0;j--)
{
if (o[j+w[i]]<o[j]+p[i])
{
o[j+w[i]]=o[j]+p[i];
if (o[j+w[i]]>sol)
sol=o[j+w[i]];
}
}
u<<sol;
return 0;
}