Cod sursa(job #2404569)

Utilizator Leonard1998Olariu Leonard Leonard1998 Data 13 aprilie 2019 01:26:39
Problema Invers modular Scor 10
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.65 kb
#include <stdio.h>

using namespace std;

long long A, M;

long long expLog_modM(int base, int pow) {
    if (pow == 0) return 1;

    long long mid = expLog_modM(base, pow >> 1);

    if (pow&1) return (base * mid * mid) % M;
    return (mid * mid) % M;
}

int main()
{
    freopen("inversmodular.in", "r", stdin);
    freopen("inversmodular.out", "w", stdout);

    scanf("%lld %lld", &A, &M);
    printf("%lld\n", expLog_modM(A, M-2));

    /*LL put = M-2;
	LL nr = A;
	LL crt = 1;
    for(LL p = 1;p <= put;p <<= 1)
    {
	 	if (p & put) crt = (crt * nr) % M;
	  	nr = (nr * nr) % M;
	}
	printf("%lld\n",crt);*/

    return 0;
}