宏观角度认识递归之 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; 
    }
}
相关推荐
不吃橘子的橘猫14 分钟前
《集成电路设计》复习资料4(Verilog HDL概述)
学习·算法·fpga开发·集成电路·仿真·半导体
宇木灵15 分钟前
C语言基础-五、数组
c语言·开发语言·学习·算法
xsyaaaan1 小时前
代码随想录Day39动态规划:115不同的子序列_583两个字符串的删除操作_72编辑距离_编辑距离总结
算法·动态规划
陈天伟教授1 小时前
人工智能应用- 人工智能交叉:05. 从 AlphaFold1 到 AlphaFold2
人工智能·神经网络·算法·机器学习·推荐算法
Eloudy1 小时前
直接法 读书笔记 05 第5章 正交方法
人工智能·算法·机器学习
iAkuya2 小时前
(leetcode)力扣100 73柱状图中最大的矩形(单调栈)
算法·leetcode·职场和发展
pp起床2 小时前
动态规划 | part03
算法·动态规划
mit6.8242 小时前
合法括号字符串|递归|树
算法
普通网友2 小时前
C++与Rust交互编程
开发语言·c++·算法
逆境不可逃2 小时前
【春节篇】LeetCode 热题 100 之 238.除了自身以外数组的乘积
数据结构·算法·leetcode