每日c/c++题 备战蓝桥杯 ([洛谷 P1226] 快速幂求模题解)

洛谷 P1226 快速幂求模题解

📌 题目链接

https://www.luogu.com.cn/problem/P1226

📝 题目描述

给定正整数 ab 和质数 p,要求计算:

复制代码
a^b % p

其中:

  • 1 ≤ a ≤ 10^9
  • 0 ≤ b ≤ 10^9
  • 2 ≤ p ≤ 10^9

💡 解题思路

1. 直接计算不可行

由于 b 的范围可达 10^9,直接计算 a^b 会导致结果过大,无法在常规数据类型中存储。因此,需要一种高效的算法来计算 a^b % p

2. 快速幂算法

快速幂算法(Exponentiation by Squaring)是一种高效计算大整数幂模的方法。其基本思想是利用二进制分解,将指数 b 转换为二进制形式,然后通过平方和乘法的方式快速计算幂值。

快速幂的递推关系:
  • b 为偶数时:a^b = (a^(b/2))^2
  • b 为奇数时:a^b = a * (a^(b-1))

通过不断将 b 右移一位(即除以 2),并根据 b 的奇偶性决定是否乘上当前的 a,可以在对数时间内计算出结果。

3. 模运算优化

在计算过程中,每一步都对结果取模 p,以避免中间结果溢出,并确保最终结果满足题目要求。

💻 代码实现

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

long long a, b, p;

int main() {
    ios::sync_with_stdio(false);
    cin.tie(0);
    cout.tie(0);
    
    cin >> a >> b >> p;
    cout << a << "^" << b << " mod " << p << "=";
    
    long long ans = 1;
    a = a % p; // 防止 a 大于 p
    
    while (b) {
        if (b & 1) { // 如果 b 是奇数
            ans = ans * a % p;
        }
        a = a * a % p; // a^2 mod p
        b >>= 1; // b 右移一位,相当于 b /= 2
    }
    
    cout << ans;
    return 0;
}

🧩 代码解析

  1. 输入处理 :使用 cin 读取输入,abp 分别表示底数、指数和模数。

  2. 初始化 :将 ans 初始化为 1,用于存储最终结果。为了防止中间结果过大,先对 a 取模 p

  3. 快速幂循环

    • b 不为 0 时,进入循环。
    • 如果 b 是奇数(即 b & 1 为真),则将当前的 a 乘到 ans 上,并对 p 取模。
    • a 自身平方,并对 p 取模。
    • b 右移一位,相当于将 b 除以 2。
  4. 输出结果:输出计算结果。

⏱️ 时间复杂度分析

快速幂算法的时间复杂度为 O(log b),其中 b 是指数。由于每次循环将 b 减半,因此循环次数为 log b。在每次循环中,进行常数次的乘法和取模操作,因此总时间复杂度为 O(log b)

🔚 总结

通过使用快速幂算法,可以在对数时间内计算大整数的幂模,避免了直接计算可能导致的溢出问题。该算法在处理大规模数据时非常高效,是解决此类问题的常用技巧。

相关推荐
半个落月2 小时前
从递归到快速排序:用 JavaScript 把分治思想讲明白
javascript·算法·面试
小月土星3 小时前
JavaScript 快速排序:从 pivot、双指针到分治思想
javascript·算法·面试
小月土星3 小时前
JavaScript 递归入门:从 1 到 n 求和,再到数组扁平化
javascript·算法·面试
To_OC19 小时前
LC 1 两数之和:面试第一道必考题,暴力解法直接被面试官 pass
javascript·算法·leetcode
鱼鱼不愚与1 天前
《原来如此 | 第01期:为什么导航软件能预测红绿灯倒计时?》
算法
博客18001 天前
酷宝的使用方法,超好用的免费界面库,C++、MFC可用
c++·mfc·界面库·库来帮·酷宝
郝学胜_神的一滴1 天前
CMake 026:属性体系精讲、四大作用域全解 & 实战代码落地
c++·cmake
复杂网络1 天前
论最小 Agent 计算机的形态
算法
kisshyshy2 天前
🍦 雪糕、食堂、火车厢:三幅漫画吃透栈、队列与链表
javascript·算法