Pagini recente » Cod sursa (job #341150) | Cod sursa (job #2847382) | Cod sursa (job #1922810) | Cod sursa (job #2538135) | Cod sursa (job #2110535)
#include <iostream>
#include <fstream>
using namespace std;
ifstream fi("rucsac.in");
ofstream fo("rucsac.out");
int dp[10010],n,g,greutate,profit,maxim=-1,k;
///i -greutate
///dp[i] profit
int main()
{
fi>>n>>g;
for(int i=1; i<=n; i++)
{
fi>>greutate>>profit;
for(int j=g-greutate; j>0; j--)
{
if(dp[j]!=0)
{
dp[j+greutate]=max(dp[j+greutate],dp[j]+profit);
}
}
dp[greutate]=max(dp[greutate],profit);
}
for(int x=1; x<=g; x++)
{
if(maxim<dp[x])
maxim=dp[x];
}
fo<<maxim;
return 0;
}