[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;
}
相关推荐
玉小格5 分钟前
一次关于Python的总结
算法
伊甸37 分钟前
从企业级项目学敏感词过滤:DFA算法与双层缓存实战
java·算法·缓存
laplaya10 分钟前
使用 vcpkg 管理 C++ 项目中的依赖
开发语言·c++
bIo7lyA8v19 分钟前
算法中的随机化思想及其复杂度收益评估的技术8
算法
数据法师24 分钟前
视频文件重复检测工具:基于哈希与视频指纹的三级筛选机制
算法·音视频·哈希算法
其实防守也摸鱼27 分钟前
软件安全与漏洞--Windows底层原理与软件逆向工程基础
linux·网络·数据库·算法·安全·安全架构·软件安全与漏洞
bIo7lyA8v1 小时前
算法稳定性与数据分布的内在联系研究的技术8
算法
blueman88882 小时前
VS2022 切换定义(F12 / Go to Definition)反应慢
c++·visual studio
bIo7lyA8v2 小时前
算法可视化对教学与调试效率的影响分析的技术8
算法
凡人叶枫2 小时前
Effective C++ 条款35:考虑 virtual 函数以外的其他选择
java·c++·spring