Pagini recente » Cod sursa (job #1395806) | Cod sursa (job #2760567) | Cod sursa (job #887837) | Cod sursa (job #1123601) | Cod sursa (job #3276001)
#include <bits/stdc++.h>
using namespace std;
ifstream in ("rucsac.in");
ofstream out ("rucsac.out");
int dp[5][10008];
int gr[5001],val[5001];
int main()
{
int n,g;
in >> n >> g;
for (int i=1; i<=n; i++) {
in >> gr[i] >> val[i];
}
for (int i=1; i<=n; i++) {
for (int j=0; j<=g; j++) {
if (gr[i]>j) {
dp[2][j]=dp[1][j];
} else {
dp[2][j]=max(dp[1][j],dp[1][j-gr[i]]+val[i]);
}
}
for (int j=0; j<=g; j++) { ///le ducem la stanga ca sa facem loc
dp[1][j]=dp[2][j];
}
}
out << dp[2][g];
return 0;
}