Cod sursa(job #108383)

Utilizator MirageRobert Sandu Mirage Data 22 noiembrie 2007 14:02:44
Problema Energii Scor 100
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.64 kb
#include <stdio.h>
int p[10000];
int main ()
{
	int g, w, e[1001],c[1001],i,j,t=0,min=10000000,max=0; 
	p[0]=1;
	FILE *in=fopen("energii.in","r"), *out=fopen("energii.out","w");
	
	fscanf(in,"%d%d",&g,&w);
	for(i=0;i<g;i++)
		{
			fscanf(in,"%d%d",&e[i],&c[i]);
			t+=e[i];
		}	
		
	if(t<w)
	{
		fprintf(out,"-1\n");
		return 0;
	}
	
	for(i=0;i<g;i++)
		for(j=w+e[i];j>=0;j--)
			if( p[j] && ( p[j+e[i]]==0 || p[j+e[i]]>p[j]+c[i] ) )
			{
				p[j+e[i]]=p[j]+c[i];
				if(max<j+e[i]) max=j+e[i];
			}
			
	min=p[max];
	
	for(i=w;i<=max;i++)
		if(p[i]&&p[i]<min) min=p[i];
	fprintf(out,"%d\n",min-1); 
	return 0;
}