Submission details
Task:Exponentiation
Sender:luukwin
Submission time:2025-11-15 12:45:23 +0200
Language:Python3 (PyPy3)
Status:READY
Result:ACCEPTED
Test results
testverdicttime
#1ACCEPTED0.10 sdetails
#2ACCEPTED0.48 sdetails
#3ACCEPTED0.46 sdetails

Code

import sys
sys.setrecursionlimit(5000)

h = int(input())
answers = []
modulo = 10**9 + 7

def modpower(x, n, m):
    u = 1 % m 
    base = x
    while n != 0:
        if (n%2==1): u = (u*base)%m
        base = (base*base) % m
        n //= 2
    return u

    if n == 0: return 1 % m 
    u = modpower(x, n//2, m)
    u =(u*u)%m
    if (n%2==1): u = (u*x)%m
    return u

for i in range(h):
    a, b = [int(x) for x in input().split()]
    # print(modpower(a, b, modulo))
    if b == 0: answers.append(str(1 % modulo))
    else: answers.append(str(modpower(a, b, modulo)))

print("\n".join(answers))

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