博客
关于我
程序员必学:快速幂算法
阅读量:472 次
发布时间:2019-03-06

本文共 1767 字,大约阅读时间需要 5 分钟。

快速幂算法是程序员必备的技能之一,了解它的实现方法和原理非常重要。以下将从基础到高级深入讲解快速幂的实现方法,并结合实际案例进行分析。

快速幂的重要性

快速幂算法能够在O(log n)的时间复杂度内完成n次幂的计算,这对于处理大数运算尤为重要。传统的乘法算法时间复杂度为O(n),在处理非常大的指数时效率低下。快速幂算法通过将指数分解为二进制形式,利用乘法的平方性质,显著提升了计算效率。

快速幂的递归实现

递归实现的快速幂算法基于以下公式:

x^n = (x^(n/2))^2 × (如果n是奇数,则再乘以x)

递归实现的代码示例如下:

int fastPower(int x, int n) {    if (n == 0) return 1;    int result = fastPower(x, n >> 1);    result *= result;    return (n & 1) == 0 ? result : result * x;}

递归实现的优点是代码简洁,逻辑清晰。每次递归将指数n减半,直到n变为0。这种方法的时间复杂度为O(log n),空间复杂度为O(log n)(递归深度)。

快速幂的非递归实现

非递归实现通过迭代的方式逐步计算幂次,避免了递归的潜在栈溢出问题。代码示例如下:

int fastPower(int x, int n) {    int result = 1;    while (n != 0) {        if ((n & 1) == 1) {            result *= x;        }        x *= x;        n >>= 1;    }    return result;}

非递归实现的优点是无限循环空间,适合处理较大的指数值。同时,通过检查n的二进制位是否为1,来决定是否需要将当前结果乘以x。

实际案例分析

以计算3^21为例,非递归实现的执行流程如下:

  • 初始:result=1, x=3, n=21(二进制为10101)
  • 进入循环:
    • n的最后一位为1,result=1×3=3,x=3×3=9,n=1010
    • n的最后一位为0,result=3,x=9×9=81,n=101
    • n的最后一位为1,result=3×81=243,x=81×81=6561,n=10
    • n的最后一位为0,result=243,x=6561×6561=43046721,n=1
    • n的最后一位为1,result=243×43046721=10460353203,x=43046721×43046721=1853020188851841,n=0
  • 最终结果为10460353203。

    Leetcode应用

    Leetcode上的第50号问题“矩阵的最短路径”可以通过快速幂算法来优化。以下是我的Java实现:

    // 递归实现double myPow(double x, int n) {    if (n == 0) return 1;    if (n == -1) return 1 / x;    double half = myPow(x, n >> 1);    half *= half;    return ((n & 1) == 1) ? half * x : half;}// 非递归实现double myPow(double x, int n) {    long y = n < 0 ? -((long) n) : n;    double result = 1.0;    while (y > 0) {        if ((y & 1) == 1) {            result *= x;        }        x *= x;        y >>= 1;    }    return n < 0 ? 1 / result : result;}

    更多练习

  • 矩阵快速幂求斐波那契数列

    利用矩阵快速幂算法,快速计算斐波那契数列的第n项。

  • 快速幂模运算

    设计一个算法,计算x^y % z的结果。

    • 输入:x、y(≥0)、z(≠0)
    • 输出:(x^y) % z
  • 欢迎在留言区留言交流,共同探讨更多算法奥秘!

    转载地址:http://ethyz.baihongyu.com/

    你可能感兴趣的文章
    NI笔试——大数加法
    查看>>
    NLog 自定义字段 写入 oracle
    查看>>
    NLog类库使用探索——详解配置
    查看>>
    NLP 基于kashgari和BERT实现中文命名实体识别(NER)
    查看>>
    NLP 项目:维基百科文章爬虫和分类【01】 - 语料库阅读器
    查看>>
    NLP_什么是统计语言模型_条件概率的链式法则_n元统计语言模型_马尔科夫链_数据稀疏(出现了词库中没有的词)_统计语言模型的平滑策略---人工智能工作笔记0035
    查看>>
    NLP学习笔记:使用 Python 进行NLTK
    查看>>
    NLP的神经网络训练的新模式
    查看>>
    NLP采用Bert进行简单文本情感分类
    查看>>
    NLP问答系统:使用 Deepset SQUAD 和 SQuAD v2 度量评估
    查看>>
    NLP:使用 SciKit Learn 的文本矢量化方法
    查看>>
    Nmap扫描教程之Nmap基础知识
    查看>>
    Nmap端口扫描工具Windows安装和命令大全(非常详细)零基础入门到精通,收藏这篇就够了
    查看>>
    NMAP网络扫描工具的安装与使用
    查看>>
    NMF(非负矩阵分解)
    查看>>
    nmon_x86_64_centos7工具如何使用
    查看>>
    NN&DL4.1 Deep L-layer neural network简介
    查看>>
    NN&DL4.3 Getting your matrix dimensions right
    查看>>
    NN&DL4.8 What does this have to do with the brain?
    查看>>
    nnU-Net 终极指南
    查看>>