Pagini recente » Cod sursa (job #668866) | Cod sursa (job #1430141) | Istoria paginii utilizator/arinaturcu | Cod sursa (job #2687780) | Cod sursa (job #993664)
Cod sursa(job #993664)
#include<cstdio>
#include<algorithm>
using namespace std;
int v[5001], p[5001],dp[2][10001],G,n;
void citire(){
freopen("rucsac.in", "r", stdin);
scanf("%d %d ", &n, &G);
for(int i = 1; i <= n; ++i)
scanf("%d %d", &v[i], &p[i]);
}
void solve(){
int i=0,j=0,result=0;
dp[0][0]=0;
int P = 0, Q = 1;
for(i = 1; i <= n; ++i) {
for(j = 1; j <= G; ++j) {
dp[Q][j] = dp[P][j];
if (j - v[i] >= 0)
dp[Q][j] = max(dp[Q][j], dp[P][j - v[i]] + p[i]);
}
P ^= 1; Q ^= 1;
}
for(i = 1; i <= G; ++i)result = max(result, dp[P][i]);
printf("%d\n", result);
}
int main(){
freopen("rucsac.out", "w", stdout);
citire();
solve();
}