lucas定理

组合数太大&&被一个素数取模

公式:

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;
}
原文地址:https://www.cnblogs.com/darlingroot/p/10359160.html