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;
    }
}
相关推荐
仰泳的熊猫14 分钟前
题目1545:蓝桥杯算法提高VIP-现代诗如蚯蚓
数据结构·c++·算法·蓝桥杯
TracyCoder12314 分钟前
LeetCode Hot100(57/100)——5. 最长回文子串
算法·leetcode·职场和发展
载数而行52019 分钟前
复杂度问题
c语言·数据结构·c++·算法·排序算法
WZ1881046386920 分钟前
LeetCode第20题
算法·leetcode
像素猎人22 分钟前
字符串/字符与整型数据的相互转换stoi/stol()和to_string()
c++·算法
蜜獾云24 分钟前
JAVA面试题速记-redis知识点
java·开发语言·redis
吕司32 分钟前
LeetCode Hot Code——三数之和
数据结构·算法·leetcode
-海绵东东-34 分钟前
图论——代码篇
算法·深度优先·图论
Drifter_yh35 分钟前
「JVM」 深入理解 StringTable:从底层编译优化到 intern 核心解密
java·jvm
金枪不摆鳍43 分钟前
hot100二分查找专题
数据结构·算法