Cod sursa(job #626984)

Utilizator blue_phoenixPosea Elena blue_phoenix Data 28 octombrie 2011 18:55:55
Problema Ridicare la putere in timp logaritmic Scor 10
Compilator cpp Status done
Runda Arhiva educationala Marime 0.44 kb
#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;
}