lucas定理

拟墨画扇 提交于 2021-02-18 11:09:24

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

公式:

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

 

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!