Pagini recente » Cod sursa (job #701106) | Cod sursa (job #46819) | Cod sursa (job #541530) | Cod sursa (job #902402) | Cod sursa (job #626983)
Cod sursa(job #626983)
#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;
}