当前位置: 首页 > article >正文

C++快速幂(递归)

文章目录

  • 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即可解决;

代码

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);


http://www.kler.cn/a/105773.html

相关文章:

  • 【Swift】类型标注、类型安全和类型推断
  • 湘潭大学软件工程算法设计与分析考试复习笔记(三)
  • 反向代理模块
  • STM32 独立看门狗(IWDG)详解
  • AcWing 1234. 倍数问题(周二)
  • 【vmware+ubuntu16.04】vm虚拟机及镜像安装-tools安装包弹不出来问题
  • elementui时间日期组件右边自定义图标
  • VS工程的“多dll与exe文件合并”
  • DevOps持续集成-Jenkins(4)
  • leetcode 146. LRU 缓存
  • (react+ts)vite项目中的路径别名的配置
  • 共享WiFi贴推广项目怎么操作?
  • el-select multiple表单校验问题
  • 「译文」深入了解Kubernetes和Nomad
  • 【嵌入式】HC32F07X ADC采样及软件滤波
  • Uniapp中嵌入H5( uniapp开发的H5),并且在H5中跳转到APP的指定页面
  • 【Docker】Docker的应用包含Sandbox、PaaS、Open Solution以及IT运维概念的详细讲解
  • 外网访问|SD-WAN跨境网络专线助力企业摆脱网络困境
  • UnrealSynth - 基于虚幻引擎的YOLO合成数据生成器
  • Redis快速上手篇五(持久化)
  • GZ035 5G组网与运维赛题第1套
  • SpringMvc接收参数
  • 31 select max/min/avg/sum/count/group_concat 的实现
  • Response Header中不暴露Server(IIS)版本、ASP.NET及相关版本等信息
  • 第六章(5):Python中的嵌套函数
  • 目标检测的方法