宏观角度认识递归之 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; 
    }
}
相关推荐
Swift社区5 小时前
LeetCode 394. 字符串解码(Decode String)
算法·leetcode·职场和发展
tt5555555555556 小时前
LeetCode进阶算法题解详解
算法·leetcode·职场和发展
让我们一起加油好吗6 小时前
【基础算法】DFS中的剪枝与优化
算法·深度优先·剪枝
Q741_1476 小时前
C++ 模拟题 力扣495. 提莫攻击 题解 每日一题
c++·算法·leetcode·模拟
Felven7 小时前
A. Be Positive
算法
小O的算法实验室7 小时前
2026年COR SCI2区,自适应K-means和强化学习RL算法+有效疫苗分配问题,深度解析+性能实测,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
青岛少儿编程-王老师8 小时前
CCF编程能力等级认证GESP—C++7级—20250927
数据结构·c++·算法
夏鹏今天学习了吗8 小时前
【LeetCode热题100(39/100)】对称二叉树
算法·leetcode·职场和发展
天选之女wow9 小时前
【代码随想录算法训练营——Day34】动态规划——416.分割等和子集
算法·leetcode·动态规划
Boop_wu10 小时前
[数据结构] 哈希表
算法·哈希算法·散列表