博客
关于我
程序员必学:快速幂算法
阅读量: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/

    你可能感兴趣的文章
    node环境下使用import引入外部文件出错
    查看>>
    node环境:Error listen EADDRINUSE :::3000
    查看>>
    Node的Web应用框架Express的简介与搭建HelloWorld
    查看>>
    Node第一天
    查看>>
    node编译程序内存溢出
    查看>>
    Node读取并输出txt文件内容
    查看>>
    node防xss攻击插件
    查看>>
    noi 1996 登山
    查看>>
    noi 7827 质数的和与积
    查看>>
    NOI-1.3-11-计算浮点数相除的余数
    查看>>
    NOI2010 海拔(平面图最大流)
    查看>>
    NOIp2005 过河
    查看>>
    NOIP2011T1 数字反转
    查看>>
    NOIP2014 提高组 Day2——寻找道路
    查看>>
    noip借教室 题解
    查看>>
    NOIP模拟测试19
    查看>>
    NOIp模拟赛二十九
    查看>>
    Vue3+element plus+sortablejs实现table列表拖拽
    查看>>
    Nokia5233手机和我装的几个symbian V5手机软件
    查看>>
    non linear processor
    查看>>