基本原理 :
代码实现: (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;
}