拓展Lucas小结
拓展Lucas是解决大组合数取模非质数(尤其是含平方因子的合数)问题的有力工具...
首先对模数质因数分解,把每个质因子单独拎出来处理答案,然后用中国剩余定理(excrt)合并
问题转化为,对于每个质因子p,求$C_{n}^{m}(mod\;p^k)$
把$C_{n}^{m}$展开成$\frac{n!}{m!(n-m)!}$,发现上下的阶乘里,都可能有质因子p,把它们从阶乘里提取出来,额外求出$n!$里p的数量,减掉$m!$和$(n-m)!$里p的数量,再乘回答案里
剩余的部分就是$n!$,$m!$和$(n-m)!$去掉p的部分,因为它们都关于模数$p^k$互质,除以$m!$和$(n-m)!$就可以用exgcd求逆元了
现在剩余的任务就是处理$n!$去掉所有p的剩余部分
比如n=19,p=3,k=2时
剩余$1*2*4*5*7*8*10*11*13*14*16*17*19(mod\;3^2)$
略微变形成$(1*2*4*5*7*8)*(10*11*13*14*16*17)*19(mod\;3^2)$
发现它竟然是一个又一个循环节,循环节长度为$p^k$,而且每一个循环节都是同模的,所以计算出一个循环节的答案,再用快速幂求得所有循环节相乘的答案
对于每个循环节,递归求解即可
每次计算还会剩余长度小于循环节一小段,因为它长度小于$p^k$,暴力计算就行了
最后合并每个质因子的答案即可模数
时间非常玄学,由出题人的毒瘤程度模数决定
代码好长啊
namespace exlucas{
ll ans=,M=;
ll son[],pw[];
int num;
int excrt_ins(ll A,ll B)
{
ll a=A,b=B,c=(a-ans%b+b)%b,x,y;
ll g=exgcd(M,b,x,y);ll bg=b/g;
if(c%g!=) return -;
//x=x*(c/g)%bg;
x=qmul(x,c/g,bg);
ans+=x*M,M*=bg,ans=(ans%M+M)%M;
return ;
}
ll get_mul(ll n,ll p,ll &sum,const ll &mo,int type)
{
if(n==) return ;
ll ans=;
for(int i=;i<=min(n,mo);i++)
if(i%p) ans=ans*i%mo;
ans=qpow(ans,n/mo,mo);
for(int i=;i<=n%mo;i++)
if(i%p) ans=ans*i%mo;
sum+=1ll*(n/p)*type;
return ans*get_mul(n/p,p,sum,mo,type)%mo;
}
ll get_C(ll n,ll m,ll p,const ll &mo)
{
if(m>n) return ;
ll sum=;ll y;
ll nn=get_mul(n,p,sum,mo,);
ll mm=get_mul(m,p,sum,mo,-);
ll nm=get_mul(n-m,p,sum,mo,-);
exgcd(mm,mo,mm,y);
mm=(mm%mo+mo)%mo;
exgcd(nm,mo,nm,y);
nm=(nm%mo+mo)%mo;
return nn*mm%mo*nm%mo*qpow(p,sum,mo)%mo;
}
ll C(ll n,ll m,const ll &mo)
{
if(m>n) return ;
ll ret=;
for(int i=;i<num;i++){
ll val=get_C(n,m,son[i],pw[i]);
excrt_ins(val,pw[i]);
}
ret=ans,M=,ans=;
return ret;
}
};
拓展Lucas小结的更多相关文章
- 数学:拓展Lucas定理
拓展Lucas定理解决大组合数取模并且模数为任意数的情况 大概的思路是把模数用唯一分解定理拆开之后然后去做 然后要解决的一个子问题是求模质数的k次方 将分母部分转化成逆元再去做就好了 这里贴一份别人的 ...
- 【拓展Lucas】模板
求\(C_n^m \mod p\),写得太丑了qwq. 第一次写拓展Lucas竟然是在胡策的时候qwq写了两个半小时啊_(:з」∠)还写挂了一个地方qwq 当然今天胡策我也是第一次写中国剩余定理(ˇˍ ...
- 【bzoj2142】【礼物】拓展Lucas定理+孙子定理
(上不了p站我要死了,侵权度娘背锅) Description 一年一度的圣诞节快要来到了.每年的圣诞节小E都会收到许多礼物,当然他也会送出许多礼物.不同的人物在小E 心目中的重要性不同,在小E心中分量 ...
- BZOJ 3129 [SDOI2013]方程 (拓展Lucas)
题目大意:给定一个方程$X_{1}+X_{2}+X_{3}+X_{4}+...+X_{n}=M$,$\forall X_{i}<=A_{i} (i<=n1)$ $\forall X_{i} ...
- BZOJ2142: 礼物(拓展lucas)
Description 一年一度的圣诞节快要来到了.每年的圣诞节小E都会收到许多礼物,当然他也会送出许多礼物.不同的人物在小E 心目中的重要性不同,在小E心中分量越重的人,收到的礼物会越多.小E从商店 ...
- 拓展lucas结论及模板
lucas及其拓展 模板题 洛谷 P4720 本文侧向结论和代码实现, 推导请转至lucas定理及其拓展的推导 https://blog.csdn.net/yuyilahanbao/article/d ...
- 『Lucas定理以及拓展Lucas』
Lucas定理 在『组合数学基础』中,我们已经提出了\(Lucas\)定理,并给出了\(Lucas\)定理的证明,本文仅将简单回顾,并给出代码. \(Lucas\)定理:当\(p\)为质数时,\(C_ ...
- 【BZOJ-2142】礼物 拓展Lucas定理
2142: 礼物 Time Limit: 10 Sec Memory Limit: 259 MBSubmit: 1313 Solved: 541[Submit][Status][Discuss] ...
- [luogu4478 BJWC2018] 上学路线 (容斥原理+拓展lucas)
传送门 Description 小B 所在的城市的道路构成了一个方形网格,它的西南角为(0,0),东北角为(N,M). 小B 家住在西南角,学校在东北角.现在有T 个路口进行施工,小B 不能通过这些路 ...
随机推荐
- ZBrush中物体的显示与隐藏
在ZBrush®中除了遮罩功能可以对局部网格进行编辑外,通过显示和隐藏局部网格也可以对局部进行控制.选择网格的控制都是手动操作,在软件中并没有相应的命令进行操作.选择局部网格的工作原理也很简单,即被选 ...
- 转载:常用 Git 命令清单
转载:常用 Git 命令清单 原文地址:http://www.ruanyifeng.com/blog/2015/12/git-cheat-sheet.html 作者: 阮一峰 我每天使用 Git , ...
- CommonJS 与 ES6 的依赖操作方法(require、import)
CommonJS:http://www.commonjs.org/specs/modules/1.0/ ES2015的 export:https://developer.mozilla.org/en- ...
- hadoop 使用java操作hdfs
1.创建目录 import java.io.IOException; import org.apache.hadoop.conf.Configuration; import org.apache.ha ...
- 【Python 学习】通过while循环和for循环猜测年龄
Python中可以通过while和for循环来限制猜测年龄的次数 1. 在猜测年龄的小程序中,不加循环的代码是这样的: age_of_yu = 23 guess_age = int(input(&qu ...
- Unity的Json解析<一>--读取Json文件
本文章由cartzhang编写,转载请注明出处. 所有权利保留. 文章链接:http://blog.csdn.net/cartzhang/article/details/50373558 作者:car ...
- windows关于定时执行的php脚本
根据业务需求,需要服务器每天定时执行一些脚本,如后台提交数据,定时处理数据库等. 最初的思路是在某个控制器里写好方法,加入code验证,定期的用计划任务去访问.由于window计划任务这方面比较low ...
- LaTeX 表格指定宽度并居中
本系列文章由 @YhL_Leo 出品,转载请注明出处. 文章链接: http://blog.csdn.net/yhl_leo/article/details/50532269 在绘制表格的时候,对于特 ...
- UML基础知识点
UML : unified Modeling Language 统一建模语言 1.对系统问题进行分析和建模 2.非专利的第三代建模和规约语言 3.UML是一种开放的方法.用于说明.可视化.构 ...
- Java并发编程(七)ConcurrentLinkedQueue的实现原理和源码分析
相关文章 Java并发编程(一)线程定义.状态和属性 Java并发编程(二)同步 Java并发编程(三)volatile域 Java并发编程(四)Java内存模型 Java并发编程(五)Concurr ...