[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;
}
相关推荐
oldmao_2000几秒前
第五章 C++内存模型与原子操作
c++
闲人不梦卿3 分钟前
数据结构之排序方法
数据结构·算法·排序算法
TracyCoder1234 分钟前
LeetCode Hot100(24/100)——21. 合并两个有序链表
算法·leetcode·链表
power 雀儿6 分钟前
前馈网络+层归一化
人工智能·算法
爱吃rabbit的mq9 分钟前
第10章:支持向量机:找到最佳边界
算法·机器学习·支持向量机
木非哲12 分钟前
AB实验高级必修课(四):逻辑回归的“马甲”、AUC的概率本质与阈值博弈
算法·机器学习·逻辑回归·abtest
CSDN_RTKLIB12 分钟前
CMake制作动态库与静态库对比
c++
wWYy.15 分钟前
C++—集群聊天室(3)CMake详解
开发语言·c++
在路上看风景21 分钟前
16. 指针和引用的区别
c++
兩尛23 分钟前
45. 跳跃游戏 II
c++·算法·游戏