宏观角度认识递归之 Pow(x,n) 问题

50. Pow(x, n) - 力扣(LeetCode)

计算 x 的 n 次幂,如果是直接暴力求解的话,会造成计算时间周期过长,所以要从别的角度出发,将幂等数分为两个幂等数相乘,例如:三的八次方,等于三的四次方乘以三的四次方,大致可以分为以下两种情况:

  1. 无法分为两个幂等数,则再乘一次 x;

  2. 可以分为两个幂等数,即转换为两个幂等数相乘;

从中也可以发现,每个轮回,都是相同的子问题;

  1. 重复子问题 -> 函数头:给定一个数 x ,要求其 n 次幂,返回结果;

  2. 解析子问题 -> 函数体:x 的 n 次幂等于两个 x 的 n/2 次幂 进行相乘,还要进行判断,判断 n%2 是否为 0 ,如果为 0,则为情况 2,如果为 1,则为情况 1,就需要再乘一次 x;

  3. 递归出口:当 n == 0 的时候,return 1;

还有一个注意点:就是 n 可以为负数,此时 x 的 n 次幂就等于 x 的 -n 次幂 的倒数;

代码实现:

java 复制代码
class Solution {
    public double myPow(double x, int n) {
        return n < 0 ? 1.0 / Pow(x,-n) : Pow(x,n);
    }
    public double Pow(double x,int n){
        if(n == 0) return 1;
        double ret = Pow(x,n/2);
        return n % 2 == 0 ? ret * ret : ret * ret * x; 
    }
}
相关推荐
Greedy Alg24 分钟前
LeetCode 72. 编辑距离(中等)
算法
xinxingrs25 分钟前
贪心算法、动态规划以及相关应用(python)
笔记·python·学习·算法·贪心算法·动态规划
秋邱37 分钟前
驾驭数据洪流:Python如何赋能您的数据思维与决策飞跃
jvm·算法·云原生·oracle·eureka·数据分析·推荐算法
侯小啾1 小时前
【23】C语言 左移(<<) 与 右移(>>) 位运算符在处理像素中的应用
c语言·算法·位运算·右移·左移
搂鱼1145141 小时前
(dp 优化)洛谷 P14460 寻雾启示 题解
算法·图论
_OP_CHEN1 小时前
算法基础篇:(十一)贪心算法拓展之区间问题:从重叠到覆盖的最优解艺术
算法·贪心算法
钟智强2 小时前
线性映射(Linear Mapping)原理详解:机器学习中的数学基石
人工智能·算法·机器学习
福尔摩斯张3 小时前
C语言核心:string函数族处理与递归实战
c语言·开发语言·数据结构·c++·算法·c#
吗~喽4 小时前
【LeetCode】滑动窗口_水果成篮_C++
c++·算法·leetcode
立志成为大牛的小牛5 小时前
数据结构——四十九、B树的删除与插入
数据结构·学习·程序人生·考研·算法