码迷,mamicode.com
首页 > 其他好文 > 详细

Pow(x, n)

时间:2015-06-11 12:52:06      阅读:110      评论:0      收藏:0      [点我收藏+]

标签:

下面介绍一下解决该问题的几种方法以及要注意的地方:

1)最直观容易想到的方法就是用递归方法求n个x的乘积,注意考虑n的正负号,时间复杂度为O(n)

class Solution {
public:
    double myPow(double x, int n) {
        if(n==0)  
            return 1.0;  
        if(n<0)  
            return 1.0/pow(x,-n);  
        return x*pow(x,n-1);  
    }
};

2)考虑到n个x相乘式子的对称关系,可以对上述方法进行改进,从而得到一种时间复杂度为O(logn)的方法,递归关系可以表示为pow(x,n) = pow(x,n/2)*pow(x,n-n/2)

class Solution {
public:
    double myPow(double x, int n) {
     if(n==0)  
        return 1.0;  
    if(n<0)  
        return 1.0/pow(x,-n);  
    double half = pow(x,n>>1);  
    if(n%2==0)  
        return half*half;  
    else  
        return half*half*x;  
    }
};

 

Pow(x, n)

标签:

原文地址:http://www.cnblogs.com/qiaozhoulin/p/4568540.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!