组合数太大&&被一个素数取模
公式:
Lucas(n,m)=C(n,m) %p =C(n %p,m %p )∗Lucas(n/p,m/p))%p
递推边界----------Lucas(i,0)=1
int C(int n,int m)
{
int ans=1;
for(int i=1;i<=m;++i)
ans*=(n-m+i)*inv[i]%p;
return ans;
}
int lucas(int n,int m)
{
if(m==0) return 1;
else return C(n%p,m%p)*lucas(n/p,m/p)%p;
}
来源:oschina
链接:https://my.oschina.net/u/4280052/blog/3654755