数值的整数次方

题目描述

给定一个double类型的浮点数base和int类型的整数exponent。求base的exponent次方。

解题思路

本题需要注意几个点:


1. 如果指数exponent是0,那么base不能为0,并且base(不为0)的exponent次方是1。


2. 如果指数exponent是负整数,那么base不能为0,并且base(不为0)的exponent次方就等于1/base的|exponent|次方,从而可以将指数化为正整数处理。


3. 如果指数exponent是正整数,那么有两种方法可以求解。第一种方法是比较朴素的方法,基于

进行求解。这种方法在指数a较大的时候,会比较慢。


第二种方法是利用指数的二进制表达式进行求解的。要求解x^a,我们首先将a转化为二进制形式,即


从而可得


定义一个变量cur,初始化为x,之后每次令cur=cur*cur。当指数a不为0时,每次取a的最后一位bi,bi只能是0或者1,如果是0,则不用处理;如果是1,将当前的cur乘到结果上。这种方法在a较大的时候会比第一种方法快。


代码

class Solution {
public:
    double Power(double base, int exponent) {
        //要考虑exponent的正负性
        double result = 1;
        
        if (exponent == 0) //为零
            return result;
        else if (exponent < 0) //为负数
        {
            if (base == 0) //不能为0
                return 0;
            
            base = 1 / base;
            exponent = -exponent; //转化为正数
        }
        
        //朴素解法
        /*
        for (int i = 0; i < exponent; i++)
            result *= base;
            */
        
        //将指数看作二进制处理
        double cur = base;
        int num = 0;
        
        while (exponent > 0)
        {
            num = exponent & 1; //取最后一位
            if (num == 1) //如果是1
                result *= cur; 
            
            cur *= cur; //更新为cur^2
            exponent >>= 1; //右移一位
        }
        
        return result;
    
    }
};


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值