Lucas 大组合数
题目:HDU 3037
题意:有n个树,m个坚果,放到n个树里,可以不放完,有多少种方法。
分析:
得到组合数了。
大组合数什么费马小定理,Lucas定理都来了;
总的说,不能用二维地推了,用的却是组合数的定义。
一般来说大组合通常要取模。
那么不能边乘边模,边除边模,等式不会成立。
根据逆元,除以一个数取模 = 乘以这个数对mod的逆元。
那么式子就可以写成:
这里,我们可以预处理所有 i 对 mod 的逆元后,累乘,这样得到的就是阶乘的逆元。
然后就是求 i 对 mod 的逆元了,什么扩展欧几里得就来了。
当然,有费马小定理。
inv[i] = (mod-mod/i)*inv[mod%i]%mod;
整个求大组合数就是这样出来了。
void init() { fac[] = ;
for(int i=;i<maxn;i++)
fac[i] = i*fac[i-]%mod; inv[] = inv[] = ;
for(int i=;i<maxn;i++)
inv[i] = (ll)(mod-mod/i)*inv[mod%i]%mod; for(int i=;i<maxn;i++)
inv[i] = inv[i-]*inv[i]%mod; } ll C(ll n,ll m) { if(n<m)
return ;
return fac[n]*inv[m]%mod*inv[n-m]%mod; }
但是这个题目n,m的范围惊人1000000000,作为阶乘,逆元,数组开不下。
Lucas来了:
看结果吧:
还是有组合数,用了费马定理:
fac[n]*Inv(fac[m])%P*Inv(fac[n-m])%P;
因为这里的对P的逆元 Inv已经不能用数组表示和地推了,Inv()函数,利用了费马定理,快速幂等等,原理很复杂了,哈哈~~~,我就不证明了。
void initFac(int n) {
fac[] = ;
for(int i=;i<=n;i++)
fac[i] = i*fac[i-]%P;
} ll Pow(ll a,int b) {
ll re = ;
for(;b;b>>=,a=a*a%P)
if(b&) re = re*a%P;
return re;
} ll Inv(ll a) {
return Pow(a,P-);
} ll C(ll n,ll m) {
if(n<m) return ;
return fac[n]*Inv(fac[m])%P*Inv(fac[n-m])%P;
} ll Lucas(ll n,ll m) {
if(n<m) return ;
ll re = ;
for(;m;n/=P,m/=P)
re = re*C(n%P,m%P)%P;
return re;
}
Lucas 大组合数的更多相关文章
- 大组合数取模之lucas定理模板,1<=n<=m<=1e9,1<p<=1e6,p必须为素数
typedef long long ll; /********************************** 大组合数取模之lucas定理模板,1<=n<=m<=1e9,1&l ...
- lucas定理解决大组合数取模
LL MyPow(LL a, LL b) { LL ret = ; while (b) { ) ret = ret * a % MOD; a = a * a % MOD; b >>= ; ...
- 大组合数:Lucas定理
最近碰到一题,问你求mod (p1*p2*p3*……*pl) ,其中n和m数据范围是1~1e18 , l ≤10 , pi ≤ 1e5为不同的质数,并保证M=p1*p2*p3*……*pl ≤ 1e18 ...
- 大组合数Lucas
https://blog.csdn.net/sr_19930829/article/details/39058487 LL Lucas(LL n, LL m, int p){ ; } Saving B ...
- HDU 5698 大组合数取模(逆元)
瞬间移动 Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total Submis ...
- poj1942 Paths on a Grid(无mod大组合数)
poj1942 Paths on a Grid 题意:给定一个长m高n$(n,m \in unsigned 32-bit)$的矩形,问有几种走法.$n=m=0$时终止. 显然的$C(m+n,n)$ 但 ...
- lightoj 1226 - One Unit Machine(dp+大组合数去摸)
题目链接:http://www.lightoj.com/volume_showproblem.php?problem=1226 题解:由于这些任务完成是有先后的所以最后一个完成的肯定是最后一个任务的子 ...
- 求大组合数mod p,(p不一定为质数)
#include<bits/stdc++.h> using namespace std; typedef long long ll; #define N 2000005 ll p; ll ...
- 【算法学习笔记】组合数与 Lucas 定理
卢卡斯定理是一个与组合数有关的数论定理,在算法竞赛中用于求组合数对某质数的模. 第一部分是博主的个人理解,第二部分为 Pecco 学长的介绍 第一部分 一般情况下,我们计算大组合数取模问题是用递推公式 ...
随机推荐
- java se系列(四) 函数、数组、排序算法、二分法、二维数组
1 函数 1.1 数的概述 发现不断进行加法运算,为了提高代码的复用性,就把该功能独立封装成一段独立的小程序,当下次需要执行加法运算的时候,就可以直接调用这个段小程序即可,那么这种封装形形式的具体表 ...
- Android应用程序组件之间的通信Intent和IntentFilter
Android应用程序的基本组件,这些基本组建除了Content Provider之外,几乎全部都是依靠Intent对象来激活和通信的. 下面介绍Intent类,并通过例子来说明Intent一般用法 ...
- VMware虚拟机上安装xp操作系统
前提:安装好虚拟机 资料:windows xp 的虚拟机操作系统 上面这个文件最好保存好一份,防止以后虚拟机用坏了可以重新安装. 1 新建目录D:\virtual machine\vSQL\vm将我们 ...
- Column 'orders' in order clause is ambiguous
今天报了这个错误 原因是.当使用sql查询语句,使用了join查表.但是这个orders没指定是哪张表的字段 ,发生在自关联情况
- Android开发_如何调用系统默认浏览器访问
Android开发_如何调用系统默认浏览器访问 2015-10-20 17:53 312人阅读 http://blog.sina.com.cn/s/blog_6efce07e010142w7.htm ...
- bzoj 2741: 【FOTILE模拟赛】L
Description FOTILE得到了一个长为N的序列A,为了拯救地球,他希望知道某些区间内的最大的连续XOR和. 即对于一个询问,你需要求出max(Ai xor Ai+1 xor Ai+2 .. ...
- jquery点滴总结
1.empty().remove().detach() empty():只移除了 指定元素中的所有子节点,而留下 了<p></p>,仍保留其在dom中所占的位置. remove ...
- [转]Create Custom Exception Filter in ASP.NET Core
本文转自:http://www.binaryintellect.net/articles/5df6e275-1148-45a1-a8b3-0ba2c7c9cea1.aspx In my previou ...
- UML建模概述
UML的组成主要有事物.图.关系. UML中的事物: (1)构件事物:UML模型的静态部分,描述概念或物理元素,包括以下 a. 类:类是对一组具有相同属性.相同操作.相同关系和相同语义的对象的抽象.包 ...
- XML深入了解(XML JavaSprint)
XMLHttpRequest 对象 XMLHttpRequest 对象用于在后台与服务器交换数据. XMLHttpRequest 对象是开发者的梦想,因为您能够: 在不重新加载页面的情况下更新网页 在 ...