卢卡斯定理 解决大数组合数求余。
来源:互联网 发布:spark 协同过滤算法 编辑:程序博客网 时间:2024/05/21 10:30
【卢卡斯(Lucas)定理】
Lucas定理用来求C(a,b)mod p的值,其中p为素数。
数学表达式为:
Lucas(a,b,q)=C(a%q,b%q)*Lucas(a/p,b/p,p);
Lucas(a,0,q)=0;
通过这个定理就可以很方便的把大数的组合转化成小数。但其中还是要求C(a%q,b%q)%p,所以这里引入逆元来求。
【定义】若整数a,b,p, 满足a·b≡1(mod p).则称a 为b 模p 的乘法逆元, 即a=b- 1mod p.其中, p 是模数。
应用到组合数中来就是:
a!/[b!*(a-b)!] % p == a! * [b!*(a-b)!]-1 %p
【逆元求法】:
应用费马小定理,a^(p-1)=1 mod p ,即 a*a^(p-2)=1 mod p也就是说 a^(p-2)就是a的逆元。当然这里求出来的逆元是在取模p的逆元,对我们最终没有影响。这也是比较方便而且比较好的方法。弄个模板来。
Lucas定理用来求C(a,b)mod p的值,其中p为素数。
数学表达式为:
Lucas(a,b,q)=C(a%q,b%q)*Lucas(a/p,b/p,p);
Lucas(a,0,q)=0;
通过这个定理就可以很方便的把大数的组合转化成小数。但其中还是要求C(a%q,b%q)%p,所以这里引入逆元来求。
【定义】若整数a,b,p, 满足a·b≡1(mod p).则称a 为b 模p 的乘法逆元, 即a=b- 1mod p.其中, p 是模数。
应用到组合数中来就是:
a!/[b!*(a-b)!] % p == a! * [b!*(a-b)!]-1 %p
【逆元求法】:
应用费马小定理,a^(p-1)=1 mod p ,即 a*a^(p-2)=1 mod p也就是说 a^(p-2)就是a的逆元。当然这里求出来的逆元是在取模p的逆元,对我们最终没有影响。这也是比较方便而且比较好的方法。弄个模板来。
这个模板不太准确,参照:http://blog.csdn.net/modiz/article/details/38119031
#include <cstdio> #include <iostream> #include <cmath> #include <cstring> #include <algorithm> using namespace std; #define maxn 100010 typedef long long LL; LL m,n,p; LL Pow(LL a,LL b,LL mod) { LL ans=1; while(b) { if(b&1) ans=(ans*a)%mod; b>>=1; a=(a*a)%mod; } return ans; } LL C(LL n,LL m) { if(n<m) return 0; LL ans=1; for(int i=1;i<=m;i++) { ans=ans*(((n-m+i)%p)*Pow(i,p-2,p)%p)%p; } return ans; } LL Lucas(LL n,LL m) { if(m==0) return 1; return (Lucas(n/p,m/p)*C(n%p,m%p))%p; }int main() { int t; scanf("%d",&t); while(t--) { scanf("%lld%lld%lld",&n,&m,&p); printf("%lld\n",Lucas(n,m)); } return 0;}
0 0
- 卢卡斯定理 解决大数组合数求余。
- lucas定理解决大数组合问题
- Lucas定理(大数组合数取模)
- lucas定理求大数组合数取模
- 大数定理
- 【模板】组合数求余--lucas定理
- 组合数模板+ 卢卡斯定理
- 组合数取模与卢卡斯定理
- 组合数之卢卡斯定理
- 大组合数取模-卢卡斯定理
- 同余模定理解决大数问题(poj1426)
- 大整数组合数求余(lucas定理)
- 组合数取模(卢卡斯定理、模板)
- bzoj2982: combination 组合数 卢卡斯定理
- hdu3037(卢卡斯定理+组合数取模)
- 大数同余定理
- 大数定理的验证
- FZU 2020-组合(Lucas定理+逆元解决大组合数求模)
- 成功安装netcdf4.1.3(20140722)
- android下用java 创建文件夹
- java float保留两位小数的做法
- cocos2d 3.2的一个简单lua demo
- 命令含运行JAVA程序
- 卢卡斯定理 解决大数组合数求余。
- 利用 NPOI 變更字體尺寸及樣式
- ECSHOP购物车退出不清空
- android ssl验证、https验证
- 如何拷贝电脑里的文件到Android手机的系统目录里
- 如何学习好 extjs
- MyEclipse中开发Hibernate应用
- iOS学习之 AFNetworking的使用(一)
- Openfire下WebServer实现