Pagini recente » Istoria paginii utilizator/ciocirlanr | Cod sursa (job #177614) | Monitorul de evaluare | Istoria paginii utilizator/gollm29 | Cod sursa (job #3228214)
#include <bits/stdc++.h>
using namespace std;
ifstream fin("rucsac.in");
ofstream fout("rucsac.out");
long long n, G, gr[5001], val[5001], dp[10001];
int main()
{
fin>>n>>G;
for(int i = 1; i <= n; i++)
fin>>gr[i]>>val[i];
long long Pmax = 0; //profitul maxim
for(int i = 1; i <= n; i++)
for(int j = G - gr[i]; j >= 0; j--)
{
dp[j+gr[i]] = max(dp[j+gr[i]], dp[j] + val[i]);
Pmax = max(Pmax, dp[j+gr[i]]);
}
fout << dp[G];
return 0;
}