Cod sursa(job #3194605)

Utilizator X2RaresRares Ionascu X2Rares Data 18 ianuarie 2024 19:09:26
Problema Invers modular Scor 0
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.65 kb
#include <iostream>
#include <fstream>
using namespace std;

ifstream fin("inversmodular.in");
ifstream fout("inversmodular.out");

int phi(int n)
{
    int r = n , d = 2;
    while(n > 1)
    {
        if(n % d == 0)
        {
            r = r / d * (d - 1);
            while(n % d == 0)
                n /= d;
        }
        d ++;
        if(d * d > n)
            d = n;
    }
    return r;
}
int pow(int a,int b)
{
    if(b==0)return 1;
    if(b%2==1)return a*pow(a,b-1);
    int P=pow(a,b/2);
    return P*P;
}
int main()
{
    long long x,y;
  fin>>x>>y;
  int a=phi(x);
  fout<<pow(x,a-1)%y;


    return 0;
}