bzoj2142 礼物——扩展卢卡斯定理
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2142
前几天学了扩展卢卡斯定理,今天来磕模板!
这道题式子挺好推的(连我都自己推出来了) ,总之就是在 n 个里取 w[1] 个,剩下的里面再取 w[2] 个,再在剩下的里面取...
这里的模数 P 一看就不是质数啊!大组合数对合数取模,就要用到扩展卢卡斯定理了;
关于扩展卢卡斯定理,可以看这篇博客:https://blog.csdn.net/clove_unique/article/details/54571216
然后模仿这篇博客写的(感觉挺清晰的):https://www.cnblogs.com/elpsycongroo/p/7620197.html
扩展卢卡斯定理也没有想象中的那么难写嘛!
代码如下:
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
typedef long long ll;
int const maxn=1e5+;
ll mod,n,m,w[],sum,p[maxn],pk[maxn],cnt,r[maxn],x,y;
void divide(ll n)
{
for(ll i=;i*i<=n;i++)
if(n%i==)
{
p[++cnt]=i; pk[cnt]=;
while(n%i==)pk[cnt]*=i,n/=i;
}
if(n>)p[++cnt]=n,pk[cnt]=n;
}
ll pw(ll a,ll b,ll pk)
{
ll ret=;
for(;b;b>>=1ll,a=(a*a)%pk)
if(b&)ret=(ret*a)%pk;
return ret;
}
void exgcd(ll a,ll b,ll &x,ll &y)
{
if(!b){x=; y=; return;}
exgcd(b,a%b,x,y);
ll t=x; x=y; y=(t-a/b*y)%mod;
}
ll inv(ll n,ll pk)
{
exgcd(n,pk,x,y); return (x%pk+pk)%pk;
}
ll fac(ll n,ll p,ll pk)// n! mod pk=p^k 且去掉 p
{
if(!n)return ;
ll ret=;
for(int i=;i<=pk;i++) if(i%p) ret=(ret*i)%pk;//一个循环节
ret=pw(ret,n/pk,pk);
for(int i=;i<=n%pk;i++) if(i%p) ret=(ret*i)%pk;
return (ret*fac(n/p,p,pk))%pk;//递归求剩余部分
}
ll exlucas(ll n,ll m,ll p,ll pk)// C(n,m) mod pk=p^k
{
if(n<m)return ;
ll a=fac(n,p,pk),b=fac(m,p,pk),c=fac(n-m,p,pk);
ll k=;//p的指数
for(ll i=n;i;i/=p)k+=i/p;
for(ll i=m;i;i/=p)k-=i/p;
for(ll i=n-m;i;i/=p)k-=i/p;
return (((a*inv(b,pk))%pk*inv(c,pk))%pk*pw(p,k,pk))%pk;//a*p^k/(b*c)
}
ll CRT()//合并模数
{
ll M=,ret=;
for(int i=;i<=cnt;i++)M*=pk[i];//pk而不是p !!!
for(int i=;i<=cnt;i++)
{
ll w=M/pk[i];
ret=(ret+w*inv(w,pk[i])*r[i])%M;
}
return (ret%M+M)%M;//
}
ll exc(ll n,ll m)// C(n,m)
{
if(n<m)return ;
for(int i=;i<=cnt;i++)
r[i]=exlucas(n,m,p[i],pk[i]);
return CRT();
}
int main()
{
scanf("%lld%lld%lld",&mod,&n,&m);
for(int i=;i<=m;i++)scanf("%lld",&w[i]),sum+=w[i];
if(sum>n){printf("Impossible\n"); return ;}
divide(mod);
ll ans=;
for(int i=;i<=m;i++)
{
ans=(ans*exc(n,w[i]))%mod;
n-=w[i];
}
printf("%lld\n",ans);
return ;
}
bzoj2142 礼物——扩展卢卡斯定理的更多相关文章
- BZOJ2142礼物——扩展卢卡斯
题目描述 一年一度的圣诞节快要来到了.每年的圣诞节小E都会收到许多礼物,当然他也会送出许多礼物.不同的人物在小E 心目中的重要性不同,在小E心中分量越重的人,收到的礼物会越多.小E从商店中购买了n件礼 ...
- [bzoj2142]礼物(扩展lucas定理+中国剩余定理)
题意:n件礼物,送给m个人,每人的礼物数确定,求方案数. 解题关键:由于模数不是质数,所以由唯一分解定理, $\bmod = p_1^{{k_1}}p_2^{{k_2}}......p_s^{{k_ ...
- 卢卡斯定理&扩展卢卡斯定理
卢卡斯定理 求\(C_m^n~mod~p\) 设\(m={a_0}^{p_0}+{a_1}^{p_1}+\cdots+{a_k}^{p_k},n={b_0}^{p_0}+{b_1}^{p_1}+\cd ...
- 【知识总结】扩展卢卡斯定理(exLucas)
扩展卢卡斯定理用于求如下式子(其中\(p\)不一定是质数): \[C_n^m\ mod\ p\] 我们将这个问题由总体到局部地分为三个层次解决. 层次一:原问题 首先对\(p\)进行质因数分解: \[ ...
- LG4720 【模板】扩展卢卡斯定理
扩展卢卡斯定理 求 \(C_n^m \bmod{p}\),其中 \(C\) 为组合数. \(1≤m≤n≤10^{18},2≤p≤1000000\) ,不保证 \(p\) 是质数. Fading的题解 ...
- 【学习笔记】扩展卢卡斯定理 exLucas
引子 求 \[C_n^m\ \text{mod}\ p \] 不保证 \(p\) 是质数. 正文 对于传统的 Lucas 定理,必须要求 \(p\) 是质数才行.若 \(p\) 不一定是质数,则需要扩 ...
- BZOJ - 2142 礼物 (扩展Lucas定理)
扩展Lucas定理模板题(貌似这玩意也只能出模板题了吧~~本菜鸡见识鄙薄,有待指正) 原理: https://blog.csdn.net/hqddm1253679098/article/details ...
- Luogu P2183 [国家集训队]礼物 扩展卢卡斯+组合数
好吧学长说是板子...学了之后才发现就是板子qwq 题意:求$ C_n^{w_1}*C_{n-w_1}^{w_2}*C_{n-w_1-w_2}^{w_3}*...\space mod \space P ...
- [BZOJ2142]礼物(扩展Lucas)
2142: 礼物 Time Limit: 10 Sec Memory Limit: 259 MBSubmit: 2286 Solved: 1009[Submit][Status][Discuss] ...
随机推荐
- RQNOJ #204 特种部队 sol
link 首先我们可以注意到一个非常无聊的性质.先一直向右边走,然后折返回来向左边走,本质上与先向右走,然后向左走,再向右走这样循环走完整个路程是一致的. 根据这个性质,我们可以将向左走与向右走两个东 ...
- (C/C++学习)23.C++中指针的长度
引言:先看下面一个程序会打印出什么? #include<iostream> using namespace std; int main() { int a = 2; int *p = &a ...
- linux基础常用语句--新手
查询:ls查看全部内容:ls -n删除:rm -rf 文件名创建目录: mkdir解压:rpm -验证是否安装:rpm -p 文件名rpm -ivh --nodeps 不需要前置条件的安装查询当前路径 ...
- LINUX-网络 - (以太网和WIFI无线)
ifconfig eth0 显示一个以太网卡的配置 ifup eth0 启用一个 'eth0' 网络设备 ifdown eth0 禁用一个 'eth0' 网络设备 ifconfig eth0 192. ...
- vue列表渲染,以及鼠标点击改变样式的问题
在实际项目中,我们进场会遇到鼠标点击该表某个DOM元素的样式,在原生的js或者jquery中,我们会比较熟练的实现这个需求,但是在vue中怎么实现呢? 直接操作DOM?NO!NO! 既然我们的项目使用 ...
- 调试LM1117电压转换芯片
LM1117(不是LM117)电源芯片是低压差线性稳压器,简称LDO(low dropout regulator),是一种非隔离(输入输出电压的地是一个地)的电压转换芯片.因此,在使用的时候,尽量让输 ...
- [luoguP1282] 多米诺骨牌(DP + 背包)
传送门 将问题转换成分组背包,每一组有上下两个,每一组中必须选则一个,上面的价值为0,下面的价值为1,求价值最小 因为要求上下两部分差值最小,只需从背包大小为总数 / 2 时往前枚举,找最小答案即可. ...
- BZOJ(7) 1085: [SCOI2005]骑士精神
1085: [SCOI2005]骑士精神 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 3233 Solved: 1911[Submit][Stat ...
- 1048 石子归并codevs
1048 石子归并codevs 题目描述 Description 有n堆石子排成一列,每堆石子有一个重量w[i], 每次合并可以合并相邻的两堆石子,一次合并的代价为两堆石子的重量和w[i]+w[i+1 ...
- Angularjs中比较实用的DateFormat库
angular.module('newApp') .factory('dateUtil', function() { var symbolMap = { 'MM': function(date) { ...