Pagini recente » Cod sursa (job #2784135) | Cod sursa (job #1410295) | Cod sursa (job #2123513) | Cod sursa (job #541996) | Cod sursa (job #626984)
Cod sursa(job #626984)
#include <stdio.h>
int main(){
unsigned int n,p;
FILE *fin=fopen("lgput.in","r");
FILE *fout=fopen("lgput.out","w");
fscanf(fin,"%u%u",&n,&p);
int i;
long long a=n,rez=1;
for(i=0;(1<<i)<=p;i++){
//pt fiecare bit din p (de la dreapta la stanga)
if((1<<i & p) >0){
//daca pe poz i in p se afla 1
rez=(rez*a)%1999999973;
}
a=a*a;//ridic totul la patrat
}
fprintf(fout,"%lld\n",rez);
return 0;
}