Cod sursa(job #3216327)
Utilizator | Radu Pelea radu._.21 | Data | 15 martie 2024 21:22:55 |
---|---|---|---|
Problema | Problema rucsacului | Scor | 100 |
Compilator | cpp-64 | Status | done |
Runda | Arhiva educationala | Marime | 0.53 kb |
#include <fstream>
using namespace std;
int n,G,dp[10001],g[5001],p[5001];
ifstream fin("rucsac.in");
ofstream fout("rucsac.out");
int main(){
fin>>n>>G;
for(int i=1;i<=n;i++)
fin>>g[i]>>p[i];
/// dp[i] = pretul maxim pentru a ajunge
/// la greutatea i
for(int i=1;i<=n;i++){
for(int j = G-g[i];j>=0;j--){
dp[j+g[i]]= max(dp[j+g[i]],dp[j]+p[i]);
}
}
int sol = 0;
for(int j=G;j>=0;j--)
sol = max(sol,dp[j]);
fout<<sol;
return 0;
}