剑指 Offer 16. 数值的整数次方

剑指 Offer 16. 数值的整数次方

剑指 Offer 16. 数值的整数次方

实现函数double Power(double base, int exponent),求base的exponent次方。不得使用库函数,同时不需要考虑大数问题。


思路

思路老简单,就是连着乘

class Solution {
    public double myPow(double x, int n) {
        double result = 1;
        if(n > 0) {
            while(n > 0){
                result = result * x;
                n--;
            }
            return result;
        }else{
            while(n < 0){
                result = result * x;
                n++;
            }
            return 1/result;
        }
    }
}

可是,超出了时间限制

这道题之前是做过的,有印象
翻了下,找到了:
数据结构与算法—Pow(x, y)、圆圈中最后剩下的数字

连思路都是一样的


问题来了,之前写的快速幂,想不起来了。。。

假设,我们要求一个数字的32次方,如果我们已经知道了它的16次方,那么,只要在16次方的基础上,再平方一次就可以了。
而16次方是8次方的平方。这样以此类推,我们求32次方只需要做5次乘法:
先求平方,在平方的基础上求4次方,在4次方的基础上求8次方,在8次方的基础上求16次方,在16次方的基础上求32次方。

bv

class Solution {
    public double myPow(double x, int n) {
        //判断n是奇数还是偶数
        boolean jiShu = (n % 2 == 0) ? false : true;
        //递归的结束条件
        if(n == 0) return 1;
        if(n == 1) return x;
        if(n == -1) return 1/x;
        double half = myPow(x, n >> 1);
        half *= half;
        //递归
        return half * (jiShu ? x : 1); 
    }
}

注意,如果使用double half = myPow(x, n/2)解答错误

在这里插入图片描述
为何使用n/2就是错误,而使用n >> 1就是正确的???

  • n为非负数时,>> 1和 /2的结果是一样的
  • n为负数且还是偶数时,>> 1和 /2的结果是一样的
  • n为负数且还是奇数时,>> 1和 /2的结果是不一样的

原因是奇数除二会发生截断现象。而>> 1和/ 2在n为负奇数时截断的反向不一样。

-5 / 2 = -(int)2.5 = -2,这里是把绝对值变小了,加个负号,结果就变大了。
-5 >> 1 = (1011) >> 1 = (1101) = -3,假设用4-bit表示一个整数,补码表示。发现结果变小了。

我们纵向比较一下

-5 / 2 = -2,5 / 2 = 2。这表明除二是向零取整
-5 >> 1 = -3,5 >> 1 = 2。这表明右移一位是向下取整

假如n = -5
x^ -3 * x^-3 * x = x^-5
x^ -2 * x^ -2 *x = x^ -3
明显是一半是-3的时候正确,因此,取 >> 1

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值