快速幂的两种算法

快速幂是一种在O(logN)的时间复杂度下求出幂的一种方法。
第一种算方法就是对于一个X^N我们可以把N转化成2进制的形式,如X^22 = X^16+X^4+X^2;因为22(二进制:10110) = 16 + 4 + 2;
所以我们可以推到出来这种算法,完整代码如下:

typedef long long ll;
ll mod_pow(ll x,ll n,ll mod){
    ll res = 1;//记录结果 
    while(n > 0){
        if(n & 1) res = res * x % mod;//判断最后一位是不是一,如果是就乘上这位对应的数。 
        x = x * x % mod;//把x向左移一位 
        n >>= 1;//舍弃最后一位,即向右移一位 
    }
    return res; 
}

还有一种算法就是先判断N是奇数还是偶数。如果是偶数满足X^N = (x^2)^(N/2);,如果是奇数满足X^N = (x^2)^(N/2)*X;则不断向下递归即可,终止条件就是N == 0时返回 1;完整代码如下:

typedef long long ll;
ll mod_pow(ll x,ll n,ll mod){
    if(n == 0)  return 1;
    ll res = mod_pow(x*x%mod,n/2,mod);
    if(n & 1) res = res*x % mod;//如果最后一位是1,则是奇数。 
    return res;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值