快速幂算法

快速幂算法:如何用 O(log n) 解决大数幂运算

引言

在计算机科学和密码学中,经常需要计算大数幂模运算(如 RSA 加密中的 m^d mod n)。当指数较大时,直接计算会导致性能问题和溢出。快速幂算法(Exponentiation by Squaring)通过二进制分解将时间复杂度从 O(n) 优化到 O(log n),成为解决这类问题的关键技术。

算法原理

1. 二进制分解

将指数 e 转换为二进制形式:

5 (十进制) = 101 (二进制)

2. 平方累乘法

  • 若当前二进制位为 1:结果乘以当前基数

  • 每位处理完后:基数平方

  • 每步执行模运算防止溢出

3. 数学表示

对于计算 a^e mod m

  • 递归式
    ae={(ae/2)2if e is evena⋅(a(e−1)/2)2if e is odd a^{e} = \begin{cases} (a^{e/2})^2 & \text{if } e \text{ is even} \\ a \cdot (a^{(e-1)/2})^2 & \text{if } e \text{ is odd} \end{cases} ae={(ae/2)2a⋅(a(e−1)/2)2if e is evenif e is odd

  • 二进制表示指数形式的递推式
    baseexp % mod=baseen−1,⋅⋅⋅,e2,e1,e0 % mod=((baseen−1<<n−1 % mod) ∗ ⋅⋅⋅∗ (baseel<<1 % mod) ∗ (basee0<<0 % mod)) % mod base^{exp} \text{ }\% \text{ } mod =base^{e_{n-1},\cdot\cdot\cdot,e{2},e{1},e{0}} \text{ }\% \text{ } mod\\ =((base^{e{n-1} << n-1}\text{ }\%\text{ }mod) \text{ }* \text{ }\cdot\cdot\cdot* \text{ }(base^{e{l} << 1}\text{ } \%\text{ } mod) \text{ }* \text{ }(base^{e{0} << 0} \text{ }\% \text{ }mod ))\text{ }\% \text{ }mod baseexp % mod=baseen−1,⋅⋅⋅,e2,e1,e0 % mod=((baseen−1<<n−1 % mod) ∗ ⋅⋅⋅∗ (baseel<<1 % mod) ∗ (basee0<<0 % mod)) % mod

    而baseibase^{i} % modbasei的结果,是逐渐翻倍的关系,即base2=(base1)2,base4=(base2)2base^{2} =(base^{1})^{2}, base^{4} = (base^{2})^{2}base2=(base1)2,base4=(base2)2

算法实现

Python 实现

python 复制代码
def fast_power(base, exponent, modulus):
    result = 1
    base = base % modulus  # 初始取模
    while exponent > 0:
        if exponent & 1:  # 当前位为1
            result = (result * base) % modulus
        base = (base * base) % modulus  # 基数平方
        exponent >>= 1  # 右移一位
    return result

C++ 实现

c++ 复制代码
long fastPower(long base, long exponent, long modulus) {
    long result = 1;
    base = base % modulus;
    while (exponent > 0) {
        if (exponent & 1)
            result = (result * base) % modulus;
        base = (base * base) % modulus;
        exponent >>= 1;
    }
    return result;
}

计算示例

示例 1:计算 3^5 mod 7

输出结果:5
示例 2:RSA 签名计算

m = 23547 # 消息

d = 132111 # 私钥

n = 824737 # 模数

signature = fast_power(m, d, n) # 输出:266749

复杂度分析

指标 说明
时间复杂度 O(log n) 指数每次循环减半
空间复杂度 O(1) 仅需常数级存储空间
性能提升 指数级 相比朴素算法 O(n) 显著优化

应用场景

密码学领域

  • RSA 加密/解密
  • 数字签名
  • Diffie-Hellman 密钥交换

计算优化

  • 大数模运算(如组合数计算)
  • 动态规划状态转移优化
  • 素数测试(Miller-Rabin算法)

总结

核心优势

  1. 二进制分解:指数按位处理
  2. 平方累乘:基数平方代替重复乘法
  3. 模运算优化:每步防溢出
  4. 位运算加速:移位代替乘除

算法意义

快速幂算法体现了"分治"思想的核心价值:

  1. 将 O(n) 问题转化为 O(log n)
  2. 解决密码学中的核心计算瓶颈
  3. 为复杂算法(如矩阵快速幂)提供基础框架
相关推荐
OopspoO2 小时前
C++杂记——Name Mangling
c++
yuanmenghao2 小时前
车载Linux 系统问题定位方法论与实战系列 - 车载 Linux 平台问题定位规范
linux·运维·服务器·网络·c++
小羊羊Python2 小时前
SoundMaze v1.0.1正式发布!
开发语言·c++
l1t2 小时前
利用DeepSeek将python DLX求解数独程序格式化并改成3.x版本
开发语言·python·算法·数独
jllllyuz2 小时前
基于子集模拟的系统与静态可靠性分析及Matlab优化算法实现
算法·matlab·概率论
程序员-King.3 小时前
day143—递归—对称二叉树(LeetCode-101)
数据结构·算法·leetcode·二叉树·递归
BlockChain8883 小时前
字符串最后一个单词的长度
算法·go
爱吃泡芙的小白白3 小时前
深入解析:2024年AI大模型核心算法与应用全景
人工智能·算法·大模型算法
阿崽meitoufa3 小时前
JVM虚拟机:垃圾收集器和判断对象是否存活的算法
java·jvm·算法