day67(1.26)——leetcode面试经典150

50. Pow(x, n)

50. Pow(x, n)

"幂为奇数" ⇨ "二进制最低位为 1" ⇨ "当前这个 2ᵏ 项要包含在结果中"

题目:

题解:

java 复制代码
class Solution {
    public double myPow(double x, int n) {
        if(x == 0.0f) {
            return 0.0d;
        }
        //用快速幂进行计算
        // 算法流程:
        // 当 x=0.0 时:直接返回 0.0 ,以避免后续 1 除以 0 操作报错。分析: 数字 0 的正数次幂恒为 0 ; 0 的 0 次幂和负数次幂没有意义,因此直接返回 0.0 即可。
        // 初始化 res=1 。
        // 当 n<0 时:把问题转化至 n≥0 的范围内,即执行 x=1/x ,n=−n 。
        // 循环计算:当 n=0 时跳出。
        // 当 n&1=1 时:将当前 x 乘入 res (即 res∗=x )。
        // 执行 x=x 
        // 2
        // (即 x∗=x )。
        // 执行 n 右移一位(即 n>>=1)。
        // 返回 res 。

        //为了防止整数溢出,所以必须直接赋值给m,再进行-
        long m = n;
        double res = 1.0;
        if(n<0) {
            x=1.0/x;
            m=-m;
        }
        while(m>0) {
            //如果幂是奇数
            if((m&1)==1) {
                res*=x;
            }
            x*=x;
            m>>=1;
        }
        return res;
    }
}
相关推荐
kyriewen11 小时前
我手写了一个 EventEmitter,面试官追问了 6 个问题——第 4 个我没答上来
前端·javascript·面试
先吃饱再说12 小时前
判断回文字符串,从一行代码到双指针优化
算法
她的男孩12 小时前
后台接口加密别只会 HTTPS,ForgeAdmin 的 RSA + SM4/AES 源码拆解
后端·面试·开源
Randyliu13 小时前
20260508-Agent搭建记录以及对ReAct框架的理解
面试·agent
ZzT14 小时前
公司用 AI 筛简历,他写了个 AI 帮你挑公司
面试·aigc·ai编程
黄敬峰14 小时前
深入理解算法核心:从递归思想、数组扁平化到快速排序
算法
PBitW14 小时前
GPT训练我的第四天,被打惨了!!!😭😭😭
前端·javascript·面试
得物技术16 小时前
从狂野代码到按目标生产:得物推荐 AI Harness 的工程化实践|AICon 演讲整理
人工智能·算法·架构
AI小老六19 小时前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程