Pagini recente » Cod sursa (job #3005568) | Cod sursa (job #1317858) | Cod sursa (job #1402365) | Cod sursa (job #2664121) | Cod sursa (job #2838233)
#include <bits/stdc++.h>
using namespace std;
#define N 10005
#define M 5005
int dp[N][M];
int main()
{
int n, G, j;
pair <int, int> v[N];
cin >> n >> G;
for(int i = 1; i <= n; i++)
cin >> v[i].first >> v[i].second;
for(int i = 1; i <= n; i++)
for(j = 0; j <= G; j++){
if(j < v[i].first)
dp[i][j] = dp[i - 1][j];
else dp[i][j] = max(dp[i - 1][j], dp[i - 1][j - v[i].first] + v[i].second);
}
cout << dp[n][G];
return 0;
}