题目
给定 组 ,对于每组数据,求出 的值。
输入格式
第一行包含整数 。
接下来 行,每行包含三个整数。
输出格式
对于每组数据,输出一个结果,表示 的值。
每个结果占一行。
数据范围
1≤≤100000
1≤≤2×
输入样例:
2
3 2 5
4 3 9
输出样例:
4
1
的三种情况:
1. 如果
2. 如果 为奇数
3. 如果 为偶数
同时,对于模运算有一个重要结论:AB % K= (A%K) * (B%K) % K
代码
#include <iostream>
#include <algorithm>
using namespace std;
typedef long long LL;
LL qmi(int a, int b, int p)
{
LL res = 1 % p;
while (b)
{
if (b & 1) res = res * a % p;
a = a * (LL)a % p;
b >>= 1;
}
return res;
}
int main()
{
int n;
scanf("%d", &n);
while (n -- )
{
int a, b, p;
scanf("%d%d%d", &a, &b, &p);
printf("%lld\n", qmi(a, b, p));
}
return 0;
}