LCR 134. Pow(x, n)

解题思路:

分治 快速幂

Java中向下取整n/=2即可

需要结合下图理解,算法就是实现的该过程

java 复制代码
class Solution {
    public double myPow(double x, int n) {
        if(x == 0.0f) return 0.0d;
        long b = n;
        double res = 1.0;
        //例如:2^-5=(1/2)^5
        if(b < 0) {
            x = 1 / x;
            b = -b;
        }
        //分奇偶讨论,为奇数时要多乘一次x
        while(b > 0) {
            //&与运算,例如:5&1=(101&001)=001=1
            if((b & 1) == 1) res *= x;
            //x=x^2
            x *= x;
            //指数地板除2(b/=2也可以)
            b >>= 1;
        }
        return res;
    }
}
相关推荐
自学小白菜2 分钟前
每周刷题 - 第三周 - 双指针专题 - 02
python·算法·leetcode
⑩-4 分钟前
简单业务异常类
java
乘风!7 分钟前
NSSM启动tomcat部署Java程序
java·服务器·后端·tomcat
杜子不疼.17 分钟前
【LeetCode76_滑动窗口】最小覆盖子串问题
算法·哈希算法
BBB努力学习程序设计20 分钟前
Java 21虚拟线程与平台线程:JVM层面的深度对比与实现原理
java
代码无疆23 分钟前
学点java字节码更易于理解一些特殊的java语法效果
java·后端
ComputerInBook26 分钟前
代数基本概念理解——特征向量和特征值
人工智能·算法·机器学习·线性变换·特征值·特征向量
BBB努力学习程序设计29 分钟前
Java 8日期时间API完全指南:告别Date和Calendar的混乱时代
java
不能只会打代码35 分钟前
力扣--3433. 统计用户被提及情况
java·算法·leetcode·力扣
知青先生41 分钟前
E9项目调试方式
java·ide