Cod sursa(job #2365339)
| Utilizator | Data | 4 martie 2019 13:05:19 | |
|---|---|---|---|
| Problema | Problema rucsacului | Scor | 80 |
| Compilator | cpp-64 | Status | done |
| Runda | Arhiva educationala | Marime | 0.6 kb |
#include<bits/stdc++.h>
using namespace std;
int n,m;
const int maxN=5000;
const int maxG=10005;
pair<int,int> v[maxN];
int dp[maxG],g;
int main()
{
freopen("rucsac.in","r",stdin);
freopen("rucsac.out","w",stdout);
scanf("%d%d",&n,&g);
for(int i=1;i<=n;i++)
scanf("%d%d",&v[i].first,&v[i].second);
for(int i=1;i<=n;i++)
{
for(int j=g-v[i].first;j>=0;j--)
dp[j+v[i].first]=max(dp[j+v[i].first],dp[j]+v[i].second);
}
int sol=0;
for(int i=0;i<=g;i++)
sol=max(sol,dp[i]);
printf("%d\n",sol);
return 0;
}
