Cod sursa(job #1984569)

Utilizator Dragne.Andrei11Dragne Andrei Dragne.Andrei11 Data 25 mai 2017 11:01:13
Problema Ridicare la putere in timp logaritmic Scor 10
Compilator cpp Status done
Runda Arhiva educationala Marime 0.45 kb
#include <bits/stdc++.h>
#define MOD 1999999973

using namespace std;

int exp_by_squaring(int a, int b)
{
    int ans = 1;
    while (b > 0)
    {
        if (b%2==1)
            ans=(a*b)%MOD;
        b/=2;
        a=(a*a)%MOD;
    }
    return ans;
}

int main()
{
    freopen("lgput.in", "r", stdin);
    freopen("lgput.out", "w", stdout);
    int n, p;
    cin>>n>>p;
    cout<<exp_by_squaring(n, p)<<'\n';

    return 0;
}