JS 实现快速幂算法

清华大佬耗费三个月吐血整理的几百G的资源,免费分享!....>>>

算法思路:

1. 如果是奇数幂,x * p(x,n-1)

 2.如果是偶数幂,p(x , n/2) * p (x, n/2)

3. 如果n=0 ,返回1

时间复杂度  : O(logN)

具体实现:

    function fastPow(x,n){  
    if(n == 0){  
    return 1;  
    }  
    else if(n % 2 == 1){  
    return fastPow(x,n-1) * x;  
    }  
    else{  
    var r = fastPow(x,n/2);  
    return r * r;  
    }  
      
    }  
      
    console.log(fastPow(2,100));