Cod sursa(job #2277369)

Utilizator AlexPascu007Pascu Ionut Alexandru AlexPascu007 Data 6 noiembrie 2018 08:43:34
Problema Energii Scor 100
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.57 kb
#include <fstream>
#define inf 100000
using namespace std;
ifstream fin("energii.in");
ofstream fout("energii.out");
int g,w,d[100010],e[5010],c[5010],i,j,minim;
int main() {
	fin>>g>>w;
	for (i=1;i<=g;i++)
		fin>>e[i]>>c[i];
	d[0]=1; minim=inf;
	for (i=1;i<=g;i++) {
		for (j=w;j>=0;j--) {
			if (d[j]!=0) {
				if (j+e[i]<w) {
					if (d[j+e[i]]==0)
						d[j+e[i]]=d[j]+c[i];
					else
						d[j+e[i]]=min(d[j+e[i]],d[j]+c[i]);
				}
				else
					minim=min(minim,d[j]+c[i]);
			}
		}
	}
	if (minim!=inf)
		fout<<minim-1;
	else
		fout<<-1;
	return 0;
}