Pagini recente » Diferente pentru utilizator/mocke intre reviziile 8 si 7 | Clasament dupa rating | Monitorul de evaluare | Monitorul de evaluare | Cod sursa (job #1999814)
#include <fstream>
#include <string>
#include <algorithm>
using namespace std;
int dp[5001][5001];
ifstream cin("rucsac.in");
ofstream cout("rucsac.out");
int main()
{
int n,g,i,j;
cin>>n>>g;
int w[n+1],p[n+1];
for(i=1;i<=n;i++)
{
cin>>w[i]>>p[i];
}
for(i=1;i<=n;i++)
{
for(j=1;j<=g;j++)
{
if(j>=w[i])
dp[i][j]=max(p[i]+dp[i-1][j-w[i]],dp[i-1][j]);
else
dp[i][j]=dp[i-1][j];
}
}
cout<<dp[n][g];
return 0;
}