C++快速幂(递归)

文章目录

C++快速幂

题目描述

LCR 134. Pow(x, n) - 力扣(LeetCode)

解题思路

借用递归的思路实现pow函数:

首先我们来举两个例子:

偶数:

2 16 2^{16} 216---> 2 8 2 ^ 8 28 * 2 8 2 ^ 8 28 | 2 8 2 ^ 8 28 ---> 2 4 2 ^ 4 24 * 2 4 2 ^ 4 24 | 2 4 2 ^ 4 24 ---> 2 2 2 ^ 2 22 * 2 2 2 ^ 2 22 | 2 2 2 ^ 2 22 ---> 2 * 2

奇数:

2 21 2 ^{21} 221---> 2 10 2 ^ {10} 210 * 2 10 2^{10} 210 * 2 2 2 | 2 10 2 ^{10} 210 ---> 2 5 2 ^ {5} 25 * 2 5 2 ^ 5 25 | 2 5 2 ^ 5 25 ---> 2 2 2 ^ 2 22 * 2 2 2^2 22 * 2 | 2 2 2 ^ 2 22 ---> 2 2 2 * 2 2 2;

从上面的例子我们也可以看出一个共同的子问题:

如果我们要计算 x n x ^ n xn 那么我们先计算 x n / 2 x ^ {n / 2} xn/2, 通过这样的方法我们就可以将计算n次方的时间复杂度降到 l o g 2 n log _2 ^ n log2n

那么答题思路就是如上所示。

细节:

当n = − 2 31 -2 ^ {31} −231的时候我们将它转成正数会越界,所以我们在转化之前将它转成longlong即可解决;

代码

cpp 复制代码
class Solution {
public:
    double myPow(double x, int n) 
    {
        return n < 0 ? 1.0 / pow(x, -(long long)n) : pow(x, n);
    }

    double pow(double x, long long n)
    {
        if(n == 0) return 1;
        double tmp = pow(x, n / 2);
        return n % 2 == 0 ? tmp * tmp : tmp * tmp * x;
    }
};

复杂度分析

时间复杂度:

采用了快速幂的算法思路我们只需要O( l o g n log^n logn)的复杂度即可解决问题;

空间复杂度:

每次递归中都声明了一个临时变量tmp,所以空间复杂度是O( l o g n log ^ n logn);

相关推荐
玖玥拾11 小时前
C/C++ 基础笔记(十四)多态与模板编程
c语言·c++·多态·模板
Roann_seo%11 小时前
C++文件操作完全指南:从文本读写到二进制文件处理
开发语言·c++
坚果派·白晓明12 小时前
【鸿蒙PC】SDL3 适配:AtomCode + Skills 快速集成 NAPI 测试工具
c++·华为·ai编程·harmonyos·atomcode
凡人叶枫13 小时前
Effective C++ 条款17:以独立语句将 newed 对象置入智能指针
java·linux·开发语言·c++·算法
凡人叶枫14 小时前
Effective C++ 条款16:成对使用 new 和 delete 时要采取相同形式
开发语言·c++·effective c++
不吃土豆的马铃薯14 小时前
C++ 高性能网络缓冲区 Buffer 源码解析
linux·服务器·开发语言·网络·c++
.千余15 小时前
【C++】C++继承入门(下):友元、静态成员与菱形继承的底层逻辑
开发语言·c++·笔记·学习·其他
初中就开始混世的大魔王15 小时前
6 Fast DDS-传输层
开发语言·c++·中间件·信息与通信
代码中介商17 小时前
C++ 智能指针完全指南(三):weak_ptr 与循环引用
开发语言·c++
BestOrNothing_201517 小时前
ROS2 C++ 小车控制完整实战(二):自定义 msg 消息发布与订阅保姆级教程
c++·ros2·subscriber·publisher·msg·topic通信·自定义接口