码迷,mamicode.com
首页 > 其他好文 > 详细

lucas定理

时间:2019-02-10 15:11:23      阅读:164      评论:0      收藏:0      [点我收藏+]

标签:atom   c99   for   als   ssis   row   span   math   col   

听着很高大上的名词

它是干什么的呢?

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

公式:

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

 

lucas定理

标签:atom   c99   for   als   ssis   row   span   math   col   

原文地址:https://www.cnblogs.com/darlingroot/p/10359160.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!