Cod sursa(job #1458649)

Utilizator RynaquiAxinte Silviu Rynaqui Data 8 iulie 2015 11:15:53
Problema Ridicare la putere in timp logaritmic Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.51 kb
#include <iostream>
#include <fstream>
using namespace std;
int subpr(long long unsigned a,long long unsigned b);
const int c=1999999973;
int main()
{
    long long unsigned a,b;
    ifstream f("lgput.in");
    ofstream g("lgput.out");
    f >> a >> b;
    g << subpr(a,b);
    return 0;
}
int subpr(long long unsigned a,long long unsigned b)
{
    if(b==0) return 1;
    else if(b==1) return a%c;
    else if(b%2==0) return subpr((a*a)%c,b/2);
    else if(b%2==1) return (a*subpr((a*a)%c,(b-1)/2))%c;
}