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;
}

 

posted @ 2019-02-10 14:05  darrrr  阅读(190)  评论(0)    收藏  举报