Cod sursa(job #2655863)
Utilizator | Data | 5 octombrie 2020 19:38:41 | |
---|---|---|---|
Problema | Ridicare la putere in timp logaritmic | Scor | 50 |
Compilator | cpp-64 | Status | done |
Runda | Arhiva educationala | Marime | 0.47 kb |
#include <fstream>
using namespace std;
int v[100];
int main()
{
ifstream cin ("lgput.in");
ofstream cout ("lgput.out");
unsigned long long int a,b,cnt=0,prod=1;
cin>>a>>b;
while(b>0)
{
cnt++;
v[cnt]=b%2;
b/=2;
}
for(int i=cnt;i>=1;i--)
{
if(v[i]==1)
prod=(prod*prod*a)%1999999973;
else
prod=(prod*prod)%1999999973;
}
cout<<prod;
return 0;
}