Pagini recente » Cod sursa (job #1169510) | Cod sursa (job #342513) | Cod sursa (job #428776) | Borderou de evaluare (job #2041128) | Cod sursa (job #2508137)
#include <fstream>
#include <vector>
#include <algorithm>
using namespace std;
int main() {
ifstream in("rucsac.in");
ofstream out("rucsac.out");
int n, g;
in >> n >> g;
vector<int> p (n);
vector<int> w(n);
for (int i = 0; i < n; ++i) {
in >> w[i] >> p[i];
}
vector<int> dp[2] ;
dp[0] = vector<int> (g+1, 0);
dp[1] = vector<int> (g+1, 0);
int lin = 0;
for (int i = 1; i <= n; ++i) {
for (int j = 0; j <= g; ++j) {
dp[lin][j] = max(dp[1-lin][j], (w[i-1] <= j) ? p[i-1] + dp[1-lin][j - w[i-1]] : 0);
}
lin = 1 - lin;
}
int res = 0;
for (int i = 0; i <= g; ++i)
res = max(res, dp[1-lin][i]);
out << res << "\n";
}