题目描述
求 a 的 b 次方对 p 取模的值。
输入格式
三个整数 a,b,p ,在同一行用空格隔开。
输出格式
输出一个整数,表示a^b mod p的值。
数据范围
1≤a,b,p≤109
输入样例:
3 2 7
输出样例:
2
a, b, p = input().split()
a = int(a)
b = int(b)
p = int(p)
'''
快速幂次乘法,把b拆成2的次幂的和,时间复杂度缩到O(log2(b))
'''
val = a
ans = 1
while b:
if b & 1:
ans = ans * val % p
val = val * val % p
b = b >> 1
print(ans % p)