Cod sursa(job #2881024)
Utilizator | Data | 30 martie 2022 11:10:48 | |
---|---|---|---|
Problema | Energii | Scor | 0 |
Compilator | cpp-64 | Status | done |
Runda | Arhiva de probleme | Marime | 0.53 kb |
#include <fstream>
using namespace std;
ifstream cin("energii.in");
ofstream cout("energii.out");
int i,j,n,gmax, g[10001], v[10001], b[10001];
int main()
{cin>>n;
cin>>gmax;
for(i=1;i<=n;i++)
{
cin>>g[i];
cin>>v[i];
}
b[0]=1;
for(i=1;i<=n;i++)
{
for(j=gmax-g[i];j>=1;j--)
if(b[j]!=0&&(b[j+g[i]]<b[j]+v[i]||b[j+g[i]]==0))
b[j+g[i]]=b[j]+v[i];
if(v[i]>b[g[i]])
b[g[i]]=v[i];
}
int ma=0;
for(i=1;i<=gmax;i++)
if(b[i]>ma)
ma=b[i];
cout<<ma;
return 0;
}