【Leetcode 每日一题 - 扩展】50. Pow(x, n)

问题背景

实现 p o w ( x , n ) pow(x, n) pow(x,n),即计算 x x x 的整数 n n n 次幂函数(即, x n x_n xn)。

数据约束

  • − 100.0 < x < 100.0 -100.0 \lt x \lt 100.0 −100.0<x<100.0
  • − 2 31 ≤ n ≤ 2 31 − 1 -2 ^ {31} \le n \le 2 ^ {31} -1 −231≤n≤231−1
  • n n n 是一个整数
  • 要么 x x x 不为零,要么 n > 0 n \gt 0 n>0。
  • − 1 0 4 ≤ x n ≤ 104 -10 ^ 4 \le x_n \le 104 −104≤xn≤104

解题过程

快速幂,思想是任何一个幂都可以对半拆成两个规模减半的子问题,并用一次乘法来得到结果。

拆解过程中要计算的幂的指数,可以通过原问题的指数 n n n 的二进制表示来得到。

具体实现

java 复制代码
class Solution {
    public double myPow(double x, int n) {
        double res = 1.0;
        // 处理指数为负的情况,转化为乘倒数
        if(n < 0) {
            n = -n;
            x = 1 / x;
        }
        while(n != 0) {
            // 如果 n 的当前数位上为 1,那么对应的幂需要作为子问题计算并累乘
            if((n & 1) == 1) {
                res *= x;
            }
            x *= x;
            n >>>= 1; // 处理完之后右移消除掉当前位
        }
        return res;
    }
}
相关推荐
Archie_IT6 分钟前
C语言程序设计P6-1【应用指针进行程序设计 | 第一节】——知识要点:指针的概念、定义和运算、指针变量作函数的参数
c语言·数据结构·算法
2401_8582861123 分钟前
111.【C语言】数据结构之二叉树的销毁函数
c语言·开发语言·数据结构·二叉树
南宫生29 分钟前
力扣-图论-7【算法学习day.57】
java·学习·算法·leetcode·深度优先·图论
枫の准大一1 小时前
【C++游记】string的使用和模拟实现
c语言·开发语言·c++·算法
lshzdq1 小时前
【机器人】控制之稳定性判定: 李雅普诺夫Lyapunov (7) 判定是否是李函数,思维导图
线性代数·算法·机器学习
java菜鸡加油1 小时前
代码随想录-算法训练营-番外(图论02:岛屿数量,岛屿的最大面积)
java·算法·leetcode·深度优先·力扣·图论
java菜鸡加油1 小时前
代码随想录-算法训练营-番外(图论01:图论理论基础,所有可到达的路径)
java·算法·leetcode·力扣·图论
weixin_429248902 小时前
机器学习经典算法
人工智能·算法·机器学习
ballball~~3 小时前
蒙特卡洛模拟(Monte Carlo Simulation)详解
算法·机器学习·蒙特卡洛模拟
乌鸦9443 小时前
《数据结构之美-- 单链表》
数据结构