Pagini recente » Cod sursa (job #1868422) | Cod sursa (job #271597) | Cod sursa (job #1433082) | Cod sursa (job #1320763) | Cod sursa (job #2636265)
#include <iostream>
#include <fstream>
using namespace std;
int dp[2][10005], n, g, w[5005], p[5005];
ifstream fin("rucsac.in");
ofstream fout("rucsac.out");
void citire() {
fin >> n >> g;
for(int i = 1; i <= n; i++)
fin >> w[i] >> p[i];
}
void solve() {
for(int i = 1; i <= n; i++)
for(int cw = 0; cw <= g; cw++) {
dp[i%2][cw] = dp[(i-1)%2][cw];
if(w[i] <= cw)
dp[i%2][cw] = max(dp[i%2][cw], dp[(i-1)%2][cw-w[i]]+p[i]);
}
}
int main() {
citire();
solve();
fout << dp[n%2][g];
}