[C++][算法基础]求a的b次方模p的值(快速幂)

给定 n 组 ,对于每组数据,求出 的值。

输入格式

第一行包含整数 n。

接下来 n 行,每行包含三个整数

输出格式

对于每组数据,输出一个结果,表示 的值。

每个结果占一行。

数据范围

1≤n≤100000,

1≤≤2×

输入样例:
复制代码
2
3 2 5
4 3 9
输出样例:
复制代码
4
1

代码:

cpp 复制代码
#include<iostream>
#include<algorithm>
using namespace std;

long long a,b;
int n,p;
const int N = 100010;

long long QuickMul(long long a,long long b,int p){
    long long res = 1;
    while(b != 0){
        if((b & 1) == 1){
            res = res * a % p;
        }
        b = b / 2;
        a = a * a % p;
    }
    return res;
}

int main(){
    cin>>n;
    while(n--){
        cin>>a>>b>>p;
        long long ans = QuickMul(a,b,p);
        cout<<ans<<endl;
    }
    return 0;
}
相关推荐
sqyno1sky9 小时前
C++中的契约编程
开发语言·c++·算法
优化控制仿真模型9 小时前
2026年最新驾考科目一考试题库2309道全。电子版pdf
经验分享·算法·pdf
qq_3349031510 小时前
嵌入式C++驱动开发
开发语言·c++·算法
阿贵---10 小时前
C++代码规范化工具
开发语言·c++·算法
暮冬-  Gentle°10 小时前
自定义内存检测工具
开发语言·c++·算法
ccLianLian10 小时前
数论·欧拉函数
数据结构·算法
2501_9454248010 小时前
C++编译期矩阵运算
开发语言·c++·算法
2301_8154829310 小时前
C++中的类型标签分发
开发语言·c++·算法
xushichao198910 小时前
代码生成优化技术
开发语言·c++·算法
炽烈小老头10 小时前
【每天学习一点算法 2026/03/22】前 K 个高频元素
学习·算法