题解 | #数值的整数次方#

数值的整数次方

http://www.nowcoder.com/practice/1a834e5e3e1a4b7ba251417554e07c00

记录题解。将次方数看作是二进制形式,然后使用位运算方法。

 public double Power(double base, int exponent) {
        if (exponent < 0){//如果exponent是负数,就调整成正数
            base = 1/base;
            exponent = -exponent;
        }
        double ret = 1.0; //用于记录结果,初始化为 1.0
        while ( exponent != 0){//循环跳出的条件,为 0 说明 已经右移到头了
            if ((exponent & 1) != 0){ //如果为1,说明此二进制为上需要进行base迭代
                ret *= base;
            }
            base *= base; //更新 base的值 至 下一二进制高位
            exponent>>=1; //将次方数进行右移,用于和 1 判断下一位 为 1 的二进制位
        }
        return ret;
    }
全部评论

相关推荐

牛客41406533...:回答他在课上学,一辈子待在学校的老教授用三十年前的祖传PPT一字一句的讲解,使用谭浩强红皮书作为教材在devc++里面敲出a+++++a的瞬间爆出114514个编译错误来学这样才显得专业
点赞 评论 收藏
分享
昨天 22:49
门头沟学院 Java
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务