Cod sursa(job #207821)

Utilizator andyciupCiupan Andrei andyciup Data 13 septembrie 2008 00:58:47
Problema Ridicare la putere in timp logaritmic Scor 10
Compilator cpp Status done
Runda Arhiva educationala Marime 0.4 kb
#include<stdio.h>
#define N 1999999973
unsigned int f(int n, int p){
	if(p==0) return 1;
	if (p==1) return n%N;
	return (((f(n, p/2))%N*(f(n, p/2)%N))%N*(f(n, p%2)%N))%N;
}

int main(){
	freopen("lgput.in", "r", stdin);
	freopen("lgput.out", "w", stdout);
	int n, p;
	scanf("%d", &n);
	scanf("%d", &p);
	n=n%N;
	p=p%(N-1);
	printf("%d\n", f(n, p));
	
	
	
	
	
	
	
	
	

	
	return 0;
}