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;
};
相关推荐
郝学胜-神的一滴18 小时前
[简化版 GAMES 101] 计算机图形学 08:三角形光栅化上
c++·unity·游戏引擎·godot·图形渲染·opengl·unreal
佳xuan18 小时前
简而言之c++
c++·算法
屯子来了18 小时前
Windows + VS2022 + UE5.2 编译 Fast DDS 2.14.0 完整记录
c++·ue5·fastdds
变量未定义~18 小时前
星际争霸、宝石塔的亮度差异、寻找食物储量
算法
YL2004042618 小时前
027合并两个有序链表
java·数据结构·算法·链表
顶点多余19 小时前
自定义协议、序列化、反序列化实现
java·linux·开发语言·c++·tcp/ip
MATLAB代码顾问19 小时前
【智能优化】无穷优化算法(INFO)原理与Python实现
开发语言·python·算法
炽烈小老头19 小时前
【每天学习一点算法 2026/05/10】合并K个排序链表
学习·算法·链表
Bruce_kaizy19 小时前
c++ linux环境编程——从应用层到linux内核深入了解文件io的调用机制(爆肝)
linux·c++·c·嵌入式linux·文件io
z2005093019 小时前
C++中的右值引用
开发语言·c++