Cod sursa(job #591772)

Utilizator Agent008Cristi Poputea Agent008 Data 25 mai 2011 16:13:22
Problema Factorial Scor 40
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.76 kb
#include<iostream.h>
#include<fstream.h>
#include<math.h>
fstream f("fact.in",ios::in), g("fact.out",ios::out);
long long contor,i,ok,ur=1,p,b,t;
int main()
{
	long long k,v,pu=5,l,o,ok2=0;
	f>>k;
	if(k==0)
		g<<i;
	else
	{while(contor<k && !ok)
		{
			i+=pu;
			contor+=ur;
			if(i==pu*5)
			{	contor++;
				ur=contor;
				pu=pu*5;
			
			}
			if(contor>k)
				ok=1;
		}
		p=pu/5;
		l=ur;v=pu;b=(ur-1)/5;o=1;ok=3;
		while(ok==3 && v<=i)
		{
			v+=p;
			l+=b;
			if(b==1)
			{	o++;
				if(o==6)
					ok=0;
			}
			if(l>k)
			{	l-=b;v-=p;b=(b-1)/5;p=p/5;o=1;}
			if(ok!=0)
				if(l==k)
					ok=1;
		}
		if(ok==0)
		{	g<<"-1";cout<<"-1";}
		else
		{	
			if(ok==3)
			{	g<<i;cout<<i;}
			else
			{	g<<v;cout<<v;}
		}
	}
	return 0;
}