Pagini recente » Borderou de evaluare (job #1335269) | Borderou de evaluare (job #1808664) | Cod sursa (job #1508351) | Borderou de evaluare (job #220104) | Cod sursa (job #1745006)
#include <iostream>
#include <fstream>
#define Q 1999999973
using namespace std;
int main()
{
unsigned long long n, p;
// open files
freopen("lgput.in", "r", stdin);
//freopen("lgput.out", "w", stdout);
// read input
cin >> n >> p;
// solve
unsigned long long m = 1;
while (p > 1)
{
if (p % 2 == 0)
{
n = (n % Q) * (p % Q);
p /= 2;
}
else
{
m = (m % Q) * (n % Q);
n = (n % Q) * (n % Q);
p = (p - 1) / 2;
}
}
n = (n % Q) * (m % Q);
// write output
cout << n;
return 0;
}