AcWing 3625:幂次方 ← 快速幂

【题目来源】
https://www.acwing.com/problem/content/3628/

【题目描述】
对任意正整数 N,计算 X^N mod 233333 的值。

【输入格式】
共一行,两个整数 X 和 N。

【输出格式】
共一行,一个整数,表示 X^N mod 233333 的值。

【数据范围】
1≤X,N≤10^9

【输入样例】
2 5

【输出样例】
32

【算法分析】
● 快速幂的模板题可参见:
洛谷 P1226:https://blog.csdn.net/hnjzsyjyj/article/details/143135845
AcWing 875:https://blog.csdn.net/hnjzsyjyj/article/details/143168167

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

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


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

● 带取模的快速幂代码
计算过程中,为了防止溢出,需要进行"取模"运算,其运算规则如下:
(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;
const int MOD=233333;

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

int main() {
    LL x,n;
    cin>>x>>n;

    cout<<fastPow(x,n,MOD)<<endl;

    return 0;
}

/*
in:
2 5

out:
32
*/

【参考文献】
https://blog.csdn.net/hnjzsyjyj/article/details/143168167
https://blog.csdn.net/hnjzsyjyj/article/details/143135845

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