快速乘的原理及其代码

基本原理 :
快速乘的原理及其代码_第1张图片

代码实现: (logn)

inline ll mult_mod(ll a, ll b, ll m)
{
    ll res = 0;
    while(b){
        if(b&1) res = (res+a)%m;
        a = (a+a)%m;
        b >>= 1;
    }
    return res;
}

快速乘其实就是来防止有两个较大的数相乘而直接乘爆, 所以用快速乘, 因为是加法, 怎么都不可能加爆. 所以目的就是为了防止爆范围. 而这里其实我也学到了O1 的防爆乘, 有些时候卡时间的话可以用这个.

inline ll mult_mod(ll a, ll b, ll m)
{
    ll c = a*b-(ll)((long double)a*b/m+0.5)*m;
    return c<0 ? c+m : c;  //就是算的a*b%m;
}

你可能感兴趣的:(矩阵快速幂/快速乘)