Cod sursa(job #2031902)
Utilizator | Data | 3 octombrie 2017 23:25:14 | |
---|---|---|---|
Problema | Ridicare la putere in timp logaritmic | Scor | 10 |
Compilator | cpp | Status | done |
Runda | Arhiva educationala | Marime | 0.45 kb |
#include <bits/stdc++.h>
using namespace std;
unsigned long long put (unsigned long long n,unsigned long long a )
{
if(a==0) return 1;
if(a==1) return n%1999999973;
if(a%2==0) return put(n*n%1999999973,a/2);
if(a%2==1) return n*put(n*n%1999999973,(a-1)/2);
}
int main()
{
ifstream f("lgput.in");
ofstream g("lgput.out");
unsigned long long a,n;
f>>n>>a;
g<<put(n,a);
return 0;
}