首页 > 其他 > 详细

Lucas定理模板

时间:2016-08-31 23:55:53      阅读:314      评论:0      收藏:0      [点我收藏+]

用于大组合数对p取模的计算。

 1 #include <cstdio>
 2 #include <iostream>
 3 #include <cmath>
 4 #include <cstring>
 5 #include <algorithm>
 6 using namespace std;
 7 #define maxn 100010
 8 typedef long long LL;
 9 
10 LL m,n,p;
11 LL Pow(LL a,LL b,LL mod)
12 {
13     LL ans=1;
14     while(b)
15     {
16         if(b&1)
17         {
18             b--;
19             ans=(ans*a)%mod;
20         }
21         b>>=1;
22         a=(a*a)%mod;
23     }
24     return ans;
25 }
26 LL C(LL n,LL m)
27 {
28     if(n<m) return 0;
29     if(m == 0) return 1;
30     if(m < 0) return 0;
31     LL ans=1;
32     for(int i=1;i<=m;i++)
33     {
34         ans=ans*(((n-m+i)%p)*Pow(i,p-2,p)%p)%p; //除以一个数的话是乘以其逆元,用到费马小定理
35     }
36     return ans;
37 }
38 LL Lucas(LL n,LL m)
39 {
40     if(m==0)
41         return 1;
42     return (Lucas(n/p,m/p)*C(n%p,m%p))%p;
43 }
44 int main()
45 {
46     while(cin>>n>>m){
47         p=1000000007;
48         LL l=n+m-4,r=n-2;
49         printf("%I64d\n",Lucas(l,r)); //计算C(l, r)
50     }
51     return 0;
52 }

 

Lucas定理模板

原文:http://www.cnblogs.com/fightfordream/p/5827825.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!