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;
    }
}
相关推荐
weixin_5112552112 小时前
更新jar内资源和代码
java·jar
m0_7066532312 小时前
模板编译期排序算法
开发语言·c++·算法
历程里程碑12 小时前
Linxu14 进程一
linux·c语言·开发语言·数据结构·c++·笔记·算法
木井巳12 小时前
【递归算法】验证二叉搜索树
java·算法·leetcode·深度优先·剪枝
不当菜虚困13 小时前
windows下HSDB导出class文件报错【java.io.IOException : 系统找不到指定的路径。】
java·开发语言
m0_5613596713 小时前
嵌入式C++加密库
开发语言·c++·算法
近津薪荼13 小时前
优选算法——双指针专题7(单调性)
c++·学习·算法
小马爱打代码13 小时前
Spring Boot:第三方 API 调用的企业级容错设计
java·spring boot·后端
j4455661113 小时前
C++中的职责链模式实战
开发语言·c++·算法
m0_6860416113 小时前
实时数据流处理
开发语言·c++·算法