Mai intai trebuie sa te autentifici.
Cod sursa(job #1563798)
| Utilizator | Data | 6 ianuarie 2016 18:52:07 | |
|---|---|---|---|
| Problema | Ridicare la putere in timp logaritmic | Scor | 100 |
| Compilator | cpp | Status | done |
| Runda | Arhiva educationala | Marime | 0.53 kb |
#include <iostream>
#include <fstream>
#define p 1999999973
using namespace std;
int a,b;
ifstream fin("lgput.in");
ofstream fout("lgput.out");
long long int Ridicare_la_putere(long long int x,long long int n)
{
if(n==0)return 1;
else if(n==1) return x%p;
else if(n%2==0) return Ridicare_la_putere((x*x)%p,n/2)%p;
else return ((x%p)*(Ridicare_la_putere((x*x)%p,(n-1)/2)%p))%p;
}
int main()
{
long long int a, putere;
fin>>a>>putere;
fout<<Ridicare_la_putere(a,putere)%p;
return 0;
}
