Cod sursa(job #1493641)
Utilizator | Data | 29 septembrie 2015 18:57:14 | |
---|---|---|---|
Problema | Problema rucsacului | Scor | 65 |
Compilator | cpp | Status | done |
Runda | Arhiva educationala | Marime | 0.45 kb |
#include <fstream>
using namespace std;
ifstream cin("rucsac.in");
ofstream cout("rucsac.out");
#define MAXN 5005
int w[MAXN],p[MAXN];
int i,j,n,g,crt,dp[MAXN];
int main()
{
cin>>n>>g;
for(i=1; i<=n; i++)
cin>>w[i]>>p[i];
for(i=1; i<=n; i++)
{
crt+=w[i]; // adun greutatea
crt=max(w[i],g);
for(j=crt; j>=w[i]; j--)
dp[j]=max(dp[j],dp[j-w[i]]+p[i]);
}
cout<<dp[g];
}