洛谷 P1226:【模板】快速幂

【题目来源】
https://www.luogu.com.cn/problem/P1226

【题目描述】
给你三个整数 a,b,p,求 a^b mod p。

【输入格式】
输入只有一行三个整数,分别代表 a,b,p。

【输出格式】
输出一行一个字符串 a^b mod p=s,其中 a,b,p 分别为题目给定的值,s 为运算结果。

【输入样例】
2 10 9

【输出样例】
2^10 mod 9=7

【说明/提示】
样例解释:2^10 =1024,1024 mod 9=7。
数据规模与约定:对于 100% 的数据,保证 0≤a,b<2^31,a+b>0,2≤p<2^31。

【算法分析】
● 快速幂,又称二进制取幂,是一个以 的时间复杂度计算 的小技巧,而暴力的计算需要 的时间复杂度。

● 快速幂的原理?
答:快速幂的原理为"++将求幂的任务按照指数 的++++二进制表示++ ++分割成更小的任务++ "。例如:


因为 个二进制位,因此当知道了 后,我们只需计算 次乘法就可以计算出

● 快速幂经典代码

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;

typedef long long LL;

int fastPow(LL a,LL n) {
    LL ans=1;
    while(n){
        if(n & 1) ans=ans*a;
        n>>=1;
        a=a*a;
    }
    return ans;
}

int main() {
    int a,n;
    cin>>a>>n;
    cout<<fastPow(a,n)<<endl;
}

/*
in:6 8
out:1679616
*/

● 带取模的快速幂代码
计算过程中,为了防止溢出,需要进行"取模"运算,其运算规则如下:
(a+b)%p=(a%p+b%p)%p
(a-b)%p=(a%p-b%p)%p
(a*b)%p=(a%p*b%p)%p

【算法代码】

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;

typedef long long LL;

int fastPow(LL a,LL b,LL p) {
    LL ans=1;
    while(b){
        if(b & 1) ans=ans*a%p;
        b>>=1;
        a=a*a%p;
    }
    return ans%p;
}

int main() {
    int a,b,p;
    cin>>a>>b>>p;
    cout<<a<<"^"<<b<<" mod "<<p<<"="<<fastPow(a,b,p)%p;
}

/*
in:2 10 9
out:2^10 mod 9=7
*/

【参考文献】
https://www.cnblogs.com/littlehb/p/15588930.html
https://oi-wiki.org/math/binary-exponentiation/

相关推荐
hnjzsyjyj1 个月前
AcWing 3625:幂次方 ← 快速幂
快速幂
Kent_J_Truman2 个月前
【魔法 / NOI】
算法·动态规划·快速幂·矩阵乘法
Czi橙5 个月前
玩玩快速冥(LeetCode50题与70题以及联系斐波那契)
java·算法·快速幂·斐波那契
聆风吟º6 个月前
算法设计与分析第二章期末总结
算法·排序算法·二分·快速幂·欧几里得
柠九~~7 个月前
快速幂算法
算法·c·快速幂
Moliay7 个月前
第十届蓝桥杯大赛个人赛省赛(软件类) C&C++ 研究生组-RSA解密
c语言·c++·蓝桥杯·快速幂·扩展欧几里得
YIN_尹1 年前
快速幂算法详解(C++实现)
java·c++·算法·快速幂
明朗晨光1 年前
AcWing90. 64位整数乘法
位运算·快速幂
theSerein1 年前
【马蹄集】—— 概率论专题:第二类斯特林数
马蹄集试题题解·快速幂·mt2231 越狱·mt2232 找朋友·mt2233 盒子与球·mt2234 点餐·第二类斯特林数