Pagini recente » Cod sursa (job #1556151) | Cod sursa (job #1774036) | Cod sursa (job #2795038) | Cod sursa (job #2087866) | Cod sursa (job #1257937)
#include <cstdio>
using namespace std;
long long rez(long long x, long long y) {
long long z=y+2;
if(y == 0)
return 1;
long long d = rez(x, y/2);
if(y%2 == 0)
return d*d%z;
else
return x%n*d*d%z;
}
int main()
{
freopen("inversmodular.in","r",stdin);
freopen("inversmodular.out","w",stdout);
long long n,p;
scanf("%lld%lld",&n,&p);
printf("%lld\n",rez(n,p-2));
return 0;
}