Pagini recente » Cod sursa (job #600570) | Cod sursa (job #2694290) | Cod sursa (job #2878893) | Cod sursa (job #811499) | Cod sursa (job #515250)
Cod sursa(job #515250)
#include <fstream>
#include <math.h>
using namespace std;
unsigned long lgpowmod(unsigned long a, unsigned long b, unsigned long c)
{
if (b == 0) {
return 1;
} else {
if (b % 2 == 0) {
return (unsigned long) pow(lgpowmod(a, b / 2, c), 2) % c;
} else {
return ((a % c) * ((unsigned long) pow(lgpowmod(a, (b - 1) / 2, c), 2) % c)) % c;
}
}
}
int main()
{
unsigned long a, b, c = 1999999973;
ifstream fin("lgput.in");
ofstream fout("lgput.out");
fin >> a >> b;
fout << lgpowmod(a, b, c);
fin.close();
fout.close();
return 0;
}