Cod sursa(job #2186366)
Utilizator | Data | 25 martie 2018 15:34:22 | |
---|---|---|---|
Problema | Energii | Scor | 100 |
Compilator | cpp | Status | done |
Runda | Arhiva de probleme | Marime | 0.45 kb |
#include <fstream>
using namespace std;
ifstream f("energii.in");
ofstream g("energii.out");
int n,m,x,y,i,j,a[8000];
int main()
{
f>>n>>m;
for(i=1;i<=m;i++) a[i]=999999;
a[0]=0;
for(i=1;i<=n;i++){
f>>x>>y;
for(j=m;j>=0;j--)
if(j+x<m){
if(a[j+x]>a[j]+y) a[j+x]=a[j]+y;
}
else if(a[m]>a[j]+y) a[m]=a[j]+y;
}
if(a[m]!=999999) g<<a[m];
else g<<-1;
return 0;
}