C++ 快速幂算法

我们思考一个问题我们怎么计算???

暴力算法当然是遍历for循环 循环n遍 但是这样时间复杂度就是O(n) 效率太低了

有没有更简单的办法?

答案是有的 就是快速幂的算法

比如我们要算我们可以

这样我们就只用计算4次就可以了

但是如果n是奇数次方怎么办?

如果是n奇数 我们可以把a存下来 计算

就是偶数了 这样我们就可以把时间复杂度降低到O(logn)

我们来看一个实际应用 斐波那契数列

我们当然可以用动态规划取写它 同时

F(n)=

化简一下

F(n)=

F(1) F(0)是已知的 我们只用求 就可以了 这个矩阵的n次方 我们就可以用上快速幂的代码了

最后 代码奉上

cpp 复制代码
class Solution
{
public:
    // 普通快速幂 a的n次方
    long long fastPower(long long a, long long n) {
        long long res = 1;
        while (n > 0) {
            if (n & 1)//判断n是不是奇数
            {
                res *= a;
            }
            a *= a;
            n >>= 1;//n/2
        }
        return res;
    }
private:int record = 1;
};
相关推荐
珊瑚里的鱼17 分钟前
第九讲 | 模板进阶
开发语言·c++·笔记·visualstudio·学习方法·visual studio
朱剑君18 分钟前
第八天——贪心算法——队列重构问题
算法·贪心算法·重构
仙人掌_lz20 分钟前
深度理解用于多智能体强化学习的单调价值函数分解QMIX算法:基于python从零实现
python·算法·强化学习·rl·价值函数
riri191940 分钟前
算法分析:蛮力法
数据结构·算法
Christo343 分钟前
关于在深度聚类中Representation Collapse现象
人工智能·深度学习·算法·机器学习·数据挖掘·embedding·聚类
摄殓永恒1 小时前
猫咪几岁
数据结构·c++·算法
机器学习之心1 小时前
分类预测 | Matlab实现ABC-Transformer人工蜂群算法优化编码器多特征分类预测/故障诊断Matlab实现
算法·matlab·分类
oioihoii1 小时前
C++23 新增的查找算法详解:ranges::find_last 系列函数
java·算法·c++23
MoonBit月兔1 小时前
插件双更新:LeetCode 刷题支持正式上线,JetBrains IDE 插件持续升级!
ide·算法·leetcode
.小墨迹1 小时前
Apollo学习——键盘控制速度
linux·开发语言·c++·python·学习·计算机外设