【ybtoj高效进阶6-4-2】方案统计【卢卡斯定理】

【ybtoj高效进阶6-4-2】方案统计

题目大意:

给定 n,m 求 C n m   m o d   10007 C_{n}^{m}\bmod 10007 Cnmmod10007的值。

思路:

n,m的范围都比 10007 大,使用卢卡斯定理
C n m = C n / p m / p ∗ C n   m o d   p m   m o d   p C_{n}^{m}=C_{n/p}^{m/p}*C_{n\bmod p}^{m\bmod p} Cnm=Cn/pm/pCnmodpmmodp
不会卢卡斯定理的 戳这里
这是一道比模板题还模板题的题。

代码:

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<queue>
#include<cstring>
#include<vector>
#define r register
#define rep(i,x,y) for(r ll i=x;i<=y;++i)
#define per(i,x,y) for(r ll i=x;i>=y;--i)
using namespace std;
typedef long long ll;
const ll V=1e5+10,p=10007;
ll t,n,m;
ll jc[V],inv[V];
ll qpow (ll x,ll y,ll p)
{
	ll ans=1;
	while(y)
	{
		if(y&1) ans=(ans*x)%p;
		x=(x*x)%p;
		y>>=1; 
	}
	return ans;
}
ll f(ll n,ll m)
{
	if(m>n) return 0;
	return (jc[n]*inv[m])%p*inv[n-m]%p;
}
ll C(ll n,ll m)
{
	if(m==0) return 1;
	return (C(n/p,m/p)*f(n%p,m%p)%p)%p;
}
int main()
{
	scanf("%lld",&t);
	jc[0]=1;
	rep(i,1,p) jc[i]=(jc[i-1]*i)%p;
	inv[p-1]=qpow(jc[p-1],p-2,p);
	per(i,p-2,0) inv[i]=(inv[i+1]*(i+1))%p;
	while(t--)
	{
		scanf("%lld%lld",&n,&m);
		printf("%lld\n",C(n,m));
	}
	return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值