Pagini recente » Cod sursa (job #53752) | Cod sursa (job #770967) | Cod sursa (job #1928942) | Cod sursa (job #2184091) | Cod sursa (job #2869358)
#include<bits/stdc++.h>
#include<fstream>
#include<vector>
#include<algorithm>
#define maxn 5001
#define maxg 10001
using namespace std;
ifstream in("rucsac.in");
ofstream out("rucsac.out");
int W[maxn],P[maxn];
int Optim[maxg];
int main()
{
int N,G;
in>>N>>G;
for (int i = 1; i <= N; ++i)
{
in>>W[i]>>P[i];
}
Optim[0] = 0;
int sol = 0;
for(int i=1;i<=N;++i)
{
for(int j=G-W[i];j>=0;--j)
{
if(Optim[j+W[i]]<Optim[j]+P[i])
{
Optim[j+W[i]]=Optim[j]+P[i];
if(Optim[j+W[i]]>sol)
{
sol=Optim[j+W[i]];
}
}
}
}
out<<sol;
return 0;
}