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;
    }
}
相关推荐
Navigator_Z30 分钟前
LeetCode //C - 964. Least Operators to Express Number
c语言·算法·leetcode
Java后端的Ai之路31 分钟前
【JDK】-JDK 17 新特性整理(比较全)
java·开发语言·后端·jdk17
郝学胜-神的一滴31 分钟前
Effective Modern C++ 条款40:深入理解 Atomic 与 Volatile 的多线程语义
开发语言·c++·学习·算法·设计模式·架构
小小小米粒35 分钟前
Spring Boot Starter ,不止是 “打包好配置的工具类包”
java·开发语言
摸鱼仙人~36 分钟前
算法题避坑指南:数组/循环范围的 `+1` 到底什么时候加?
算法
liliangcsdn42 分钟前
基于似然比的显著图可解释性方法的探索
人工智能·算法·机器学习
骇城迷影44 分钟前
代码随想录:二叉树篇(中)
数据结构·c++·算法·leetcode
Zhu_S W1 小时前
深入理解哈希表:原理、源码与设计哲学
数据结构·散列表
期末考复习中,蓝桥杯都没时间学了1 小时前
力扣刷题23
算法·leetcode·职场和发展
菜鸡儿齐1 小时前
leetcode-子集
算法·leetcode·深度优先