最近在刷数论的题目什么扩展欧几里得,卢卡斯 发现我高中学的东西都忘记了,我做了一道等比数列求和的问题,我直接推出结论然后想用快速幂直接解决问题但是被卡时间了,超时了,我看见大佬们有两种做法,一种是二分快速幂,一种就直接快速乘的方式就省了时间,下面是模板a^b mod p;
typedef long long ll;
ll mul(ll a,ll b,ll p){
ll res=0;
while (b != 0)
{
if (b&1)
res = (res+a)%p;
b = b >> 1;
a = (a+a)%p;
}
return res;
}
ll qmi(ll a,ll b,ll p){
ll ans=1;
while(b){
if(b&1)ans=mul(ans,a,p);
b>>=1;
a=mul(a,a,p);
}
return ans;
}