Pow(x, n)

方法:采用分治的方法,x^n = x^n/2*x^n/2*x^n%2;

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

 

posted @ 2017-06-10 18:12  chengcy  Views(79)  Comments(0Edit  收藏  举报