Cod sursa(job #251821)

Utilizator ZillaMathe Bogdan Zilla Data 3 februarie 2009 13:53:44
Problema Ridicare la putere in timp logaritmic Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.46 kb
#include <stdio.h>

FILE *f=fopen("lgput.in","r"),*g=fopen("lgput.out","w");
long long y=1999999973;

long long ridicare(long long n, long long p)
{
    if(p==0)
        return 1;
	if(p==1)
		return n%y;
	else
		if(p%2==1)
			return ((n%y)*(ridicare(n,p-1)%y))%y;
		else
			return (ridicare((n*n)%y,p/2))%y;
}

int main()
{

	long long z;
	long long n,p,x;
	fscanf(f,"%lld%lld",&n,&p);
	z=ridicare(n,p)%y;
    fprintf(g,"%lld",x);
	return 0;
}