Cod sursa(job #626983)
| Utilizator | Data | 28 octombrie 2011 18:54:25 | |
|---|---|---|---|
| Problema | Ridicare la putere in timp logaritmic | Scor | 10 |
| Compilator | cpp | Status | done |
| Runda | Arhiva educationala | Marime | 0.42 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*=a;
}
a=a*a;//ridic totul la patrat
}
fprintf(fout,"%lld\n",rez);
return 0;
}
