Submission details
Task:Exponentiation
Sender:ariadna.roga
Submission time:2025-11-15 10:50:11 +0200
Language:C++ (C++17)
Status:READY
Result:ACCEPTED
Test results
testverdicttime
#1ACCEPTED0.01 sdetails
#2ACCEPTED0.42 sdetails
#3ACCEPTED0.50 sdetails

Code

#include <bits/stdc++.h>

using namespace std;

long long module_exponentiation(long long a, long long b, long long MOD) {
    if (b == 0) 
        return 1%MOD;
    else if (b%2 == 0) {
        long long half = module_exponentiation(a, b / 2, MOD) % MOD;
        return (half * half) % MOD;
    }
    else {
        return (module_exponentiation(a, b - 1, MOD) % MOD * a) % MOD;
    }
}

int main()
{
    ios_base::sync_with_stdio(0);
    cin.tie(0);

    long long n;
    cin >> n;

    long long MOD = 1000000007;

    for (long long i = 0; i < n; ++i) {
        long long a, b;
        cin >> a >> b;

        cout << module_exponentiation(a, b, MOD) << "\n";
    }
}

Test details

Test 1

Verdict: ACCEPTED

input
10201
0 0
0 1
0 2
0 3
...

correct output
1
0
0
0
0
...

user output
1
0
0
0
0
...
Truncated

Test 2

Verdict: ACCEPTED

input
200000
129612095 411099530
241615980 487174929
60862511 511830781
758816482 982657640
...

correct output
276067146
838400234
148093882
546897305
467086232
...

user output
276067146
838400234
148093882
546897305
467086232
...
Truncated

Test 3

Verdict: ACCEPTED

input
200000
692427692 536870911
252480658 536870911
505090334 536870911
27194853 536870911
...

correct output
940305728
707431813
917260341
908974199
375947818
...

user output
940305728
707431813
917260341
908974199
375947818
...
Truncated