Pagini recente » Cod sursa (job #2767119) | Cod sursa (job #1255587) | Cod sursa (job #722607) | Cod sursa (job #3225303) | Cod sursa (job #1853213)
#include <fstream>
using namespace std;
ifstream fin("rucsac.in");
ofstream fout("rucsac.out");
int n,g;
struct obj
{
int pret;
int greutate;
}v[5005];
int d[5005];
int sum_max;
int main()
{
fin>>n>>g;
for (int i=0;i<n;i++) {
fin>>v[i].greutate>>v[i].pret;
}
d[0]=1;
for (int i=0;i<n;i++) {
for (int j=g-v[i].greutate;j>=0;--j) {
if (d[j+v[i].greutate]<d[j]+v[i].pret) {
d[j+v[i].greutate]=d[j]+v[i].pret;
}
}
}
for (int i=0;i<=g;i++) if (d[i]>sum_max) sum_max=d[i];
fout<<sum_max-1;
}