Cod sursa(job #3167416)
| Utilizator | Data | 10 noiembrie 2023 18:29:20 | |
|---|---|---|---|
| Problema | Ridicare la putere in timp logaritmic | Scor | 100 |
| Compilator | cpp-64 | Status | done |
| Runda | Arhiva educationala | Marime | 0.52 kb |
#include <iostream>
#include <fstream>
using namespace std;
ifstream fin("lgput.in");
ofstream fout ("lgput.out");
void lgput(const unsigned long long a,unsigned long long n,unsigned long long p){
unsigned long long b=1;
while(p!=0){
if(p%2==1){
b=b*n%a;
p--;
}
else{
p=p/2;
n=n*n%a;
}
}
fout<<b;
}
int main()
{
const unsigned long long a=1999999973;
unsigned long long n,p;
fin>>n>>p;
lgput(a,n,p);
return 0;
}
