#include <iostream>
#include <vector>
using namespace std;
int knapSack(vector<int> &weights, vector<int> &values, int n, int capacity) {
vector<vector<int> > dp(n + 1, vector<int>(capacity + 1, 0));
for (int i = 1; i <= n; i++) {
for (int j = 1; j <= capacity; j++) {
if (weights[i - 1] <= j) {
dp[i][j] =
max(dp[i - 1][j], dp[i - 1][j - weights[i - 1]] + values[i - 1]);
} else {
dp[i][j] = dp[i - 1][j];
}
}
}
return dp[n][capacity];
}
int main() {
vector<int> weights = {2, 3, 4};
vector<int> values = {3, 4, 5};
int capacity = 5;
int n = values.size();
cout << knapSack(weights, values, n, capacity) << endl;
return 0;
}