Pagini recente » Monitorul de evaluare | Istoria paginii runda/andrei_15 | Istoria paginii runda/fcgd | Monitorul de evaluare | Cod sursa (job #1569090)
#include <bits/stdc++.h>
using namespace std;
int w[6000],p[6000],dp[2][10009];
ifstream in("rucsac.in");
ofstream out("rucsac.out");
int main()
{
int g,n;
in>>n>>g;
for(int i=1;i<=n;i++)
in>>w[i]>>p[i];
int act=1;
int last=0;
for(int i=1;i<=n;i++)
{ swap(act,last);
for(int s=0;s<=g;s++)
{ dp[act][s]=dp[last][s];
if(s-w[i]>=0)
dp[act][s]=max(dp[act][s],dp[last][s-w[i]]+p[i]);
}
}
int ans=-1;
for(int i=0;i<=g;i++)
ans=max(ans,dp[act][i]);
out<<ans;
return 0;
}