Cod sursa(job #1258057)

Utilizator czlateaZlatea Cezar czlatea Data 8 noiembrie 2014 13:39:03
Problema Invers modular Scor 60
Compilator cpp Status done
Runda Arhiva educationala Marime 0.46 kb
#include <cstdio>

using namespace std;
long long n;
long long lgput(long long a, long long b) {

    if(b == 0)
        return 1;

    long long d = lgput(a, b/2);

    if(b%2 == 0)
        return d*d%n;
    else
        return d*d%n*a%n;
}

int main()
{
    freopen("inversmodular.in","r",stdin);
    freopen("inversmodular.out","w",stdout);
    long long a;
    scanf("%lld%lld",&a,&n);
    printf("%lld\n",lgput(a,n-2));
    return 0;
}