Lucas定理

Posted ws_zzy

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Lucas定理相关的知识,希望对你有一定的参考价值。

模板

公式:Lucas(n,m)=C(n%p,m%p)*Lucas(n/p,m/p)

Lucas定理保证了求C时逆元存在

注意逆元存在条件

不会证明

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
typedef long long Lint;
const int maxn=200009;

int T;
 
int n,m,mm;
Lint f[maxn];
Lint Ksm(Lint a,int p){
	Lint ret=1;
	for(;p;p>>=1,a=a*a%mm){
		if(p&1)ret=ret*a%mm;
	}
	return ret;
}
Lint Inv(Lint x){
	return Ksm(x,mm-2);
}

Lint C(int n,int m){
	if(m>n)return 0;
	return f[n]*Inv(f[m])*Inv(f[n-m])%mm;
}
Lint Lucas(int n,int m){
	if(m==0)return 1;
	return C(n%mm,m%mm)*Lucas(n/mm,m/mm)%mm;
}

int main(){
	scanf("%d",&T);
	while(T--){
		scanf("%d%d%d",&n,&m,&mm);
		n=n+m;
		f[0]=1;
		for(int i=1;i<=n;++i)f[i]=f[i-1]*i%mm;
		printf("%lld\n",Lucas(n,m));
	}
	return 0;
}

  

以上是关于Lucas定理的主要内容,如果未能解决你的问题,请参考以下文章

数论Lucas定理

FZU 2020 组合 (Lucas定理)

HDU 3037 Saving Beans (数论,Lucas定理)

lucas定理

HDU Interesting Yang Yui Triangle (Lucas定理)

Lucas定理及应用