Cod sursa(job #705281)

Utilizator span7aRazvan span7a Data 3 martie 2012 22:24:20
Problema Energii Scor 5
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.74 kb
#include<stdio.h>
#include<algorithm>
using namespace std;
int cost,E[100000],C[100000],ok,s,i,W,G,costmin;
int main()
{
	freopen("energii.in","r",stdin);
	freopen("energii.out","w",stdout);
	scanf("%d",&G);
	scanf("%d",&W);
	for(i=1;i<=G;i++)
	{
		scanf("%d",&E[i]);
		s=s+E[i];
		scanf("%d",&C[i]);
	}
	for(i=1;i<=G;i++)
		if(E[i]>=W)
			costmin=C[i];
	if(s<W)
		printf("-1");
	else
	{
	do
	{
		ok=1;
		for(i=1;i<G;i++)
			if(C[i]>C[i+1]&&E[i]<E[i+1])
				{swap(C[i],C[i+1]);
				swap(E[i],E[i+1]);ok=0;
				}
	}while(ok==0);
	
	while(cost<=W&&i<=G)
	{
		cost+=C[i];
		i++;
		
	}
	if(cost<W&&i<G)
	{cost+=C[++i];
	}
	if(cost<=costmin)
	printf("%d",cost);
	else
		printf("%d",costmin);
	}
	
	
	return 0;
}