卢卡斯定理Lucas
卢卡斯定理Lucas
在数论中,\(Lucas\)定理用于快速计算\(C^m_n ~ \% ~p\),即证明\(C^m_n = \prod_{i = 0} ^kC^{m_i}_{n_i}\)其中\(m_i\)为\(m\)的因式分解,\(n_i\)为\(n\)的因式分解,\(p\)为质数。
由\(Edward~Lucas\)在1878年提出。
证明:
首先我们将\(C^i_p\)进行一下变式即\(C^i_j = \frac{p!}{i!(p - i)!}\),提出来一个\(\frac{p}{i}\)也就等于\(\frac{p}{i} \times \frac{(p - 1)!}{(i - 1)!(p - i)}\)。因此我们推出:
\(C^i_p \equiv \frac{p}{i}C^{i - 1}_{P - 1} \equiv 0 ~(mod~p)\)。其中\(1 \leq i \leq p - 1\)
然后我们得到:
\((X +1)^p \equiv C_p^01^p + C_p^1X^2 + ... + C_P^PX^P\)(实际上就是个多项式展开...)
同时又同余\(C_p^01^pX^0 + C_p^p1^0X^p \equiv 1 + X^p (mod ~p)\)
因此我们又推出:
\((1 + X)^p \equiv 1 + X^p (mod ~ p)\)
接着我们可以利用数学归纳法求出\((1 +X)^{p^i} \equiv 1 + X^{p^i} (mod~ p)\)。接下来将\(m\)用\(p\)进制数表示就是\(\sum_{i = 0} ^km_ip^i\)。
并且我们还可以看出\(\sum_{n = 0}^{m} C_n^mX^n = (1 +X)^m = \prod _{i = 0}^k((1 + X)^{p^i})^{m_i} = \prod _{i = 0}^k(1 + X^{p^i})^{m_i} = \prod _{i = 0}^k(\sum_{n_i = 0}^{m_i} C_{n_i}^{m_i}X^{n_ip^i})\)
也就等于\(\prod _{i = 0}^k(\sum_{n_i = 0}^{p - 1} C_{n_i}^{m_i}X^{n_ip^i}) = \sum_{n_i = 0}^{k} (\prod_{i - 0}^kC_{n_i}^{m_i})X^n ~ (mod ~ p)\)
因为\(n_i\)为\(n\)的\(p\)进制表示,因此得证。
模板:(Link)
#include <iostream>
#include <cstdio>
#include <vector>
#include <cstring>
#include <algorithm>
using namespace std ;
typedef long long LL ;
const int MAXN = 100010 ;
LL N, M, P, X[MAXN] ;
inline LL Read() {
LL X = 0, F = 1 ; char ch = getchar() ;
while (ch > '9' || ch < '0') F = (ch == '-' ? - 1 : 1), ch = getchar() ;
while (ch >= '0' && ch <= '9') X=(X<<1)+(X<<3)+(ch^48), ch = getchar() ;
return X * F ;
}
inline LL QuickPow(LL A, LL B) {
LL Ans = 1 ; if (! B) return 1 % P ;
while (B) {
if (B & 1) Ans = Ans * A % P ;
A = A * A % P, B >>= 1 ;
} return Ans ;
}
inline LL C(LL A, LL B) {
if (B > A) return 0 ;
return (X[A] * QuickPow(X[B], P - 2)) % P * QuickPow(X[A - B], P - 2) % P ;
}
inline LL Lucas(LL A, LL B) {
if (! B) return 1 ;
else return (C(A % P, B % P) * Lucas(A / P, B / P)) % P ;
}
int main() {
int T = Read() ; while (T --) {
N = Read(), M = Read(), P = Read() ;
X[0] = 1 ;
for (LL i = 1 ; i <= P ; i ++)
X[i] = (X[i - 1] * i) % P ;
LL Ans = Lucas(N + M, N) ;
printf("%lld\n", Ans) ;
} return 0 ;
}
卢卡斯定理Lucas的更多相关文章
- 【luogu P3807】【模板】卢卡斯定理/Lucas 定理(含 Lucas 定理证明)
[模板]卢卡斯定理/Lucas 定理 题目链接:luogu P3807 题目大意 求 C(n,n+m)%p 的值. p 保证是质数. 思路 Lucas 定理内容 对于非负整数 \(n\),\(m\), ...
- 卢卡斯定理 Lucas (p为素数)
证明摘自:(我网上唯一看得懂的证明) https://blog.csdn.net/alan_cty/article/details/54318369 结论:(显然递归实现)lucas(n,m)=luc ...
- 洛谷.3807.[模板]卢卡斯定理(Lucas)
题目链接 Lucas定理 日常水题...sublime和C++字体死活不同步怎么办... //想错int范围了...不要被longlong坑 //这个范围现算阶乘比预处理快得多 #include &l ...
- Lucas 卢卡斯定理
Lucas: 卢卡斯定理说白了只有一条性质 $$ C^n_m \equiv C^{n/p}_{m/p} \times C^{n \bmod p}_{m \bmod p} \ (mod \ \ p) $ ...
- 数论篇7——组合数 & 卢卡斯定理(Lucas)
组合数 组合数就是高中排列组合的知识,求解组合数C(n,m),即从n个相同物品中取出m个的方案数. 求解方式 求解通式:$C^{m}_{n}=\dfrac {n!}{m!\left( n-m\righ ...
- CRT中国剩余定理 & Lucas卢卡斯定理
数论_CRT(中国剩余定理)& Lucas (卢卡斯定理) 前言 又是一脸懵逼的一天. 正文 按照道理来说,我们应该先做一个介绍. 中国剩余定理 中国剩余定理,Chinese Remainde ...
- 【BZOJ4403】序列统计(组合数学,卢卡斯定理)
[BZOJ4403]序列统计(组合数学,卢卡斯定理) 题面 Description 给定三个正整数N.L和R,统计长度在1到N之间,元素大小都在L到R之间的单调不降序列的数量.输出答案对10^6+3取 ...
- 【Luogu3807】【模板】卢卡斯定理(数论)
题目描述 给定\(n,m,p(1≤n,m,p≤10^5)\) 求 \(C_{n+m}^m mod p\) 保证\(P\)为\(prime\) \(C\)表示组合数. 一个测试点内包含多组数据. 输入输 ...
- 【数论】卢卡斯定理模板 洛谷P3807
[数论]卢卡斯定理模板 洛谷P3807 >>>>题目 [题目] https://www.luogu.org/problemnew/show/P3807 [输入格式] 第一行一个 ...
随机推荐
- Oracle数据库web维护管理及监控
1.Oracle数据库客户端的种类及现状 目前Oracle数据库维护管理,通常是使用客户端软件:PL/SQL Developer,SQL* Plus,toad,em等进行数据的管理.维 ...
- #include <unistd.h> 的作用
原文:http://blog.csdn.net/ybsun2010/article/details/24832113 由字面意思,unistd.h是unix std的意思,是POSIX标准定义的uni ...
- C++多线程编程(★入门经典实例★)
原文:http://www.cnblogs.com/codingmengmeng/p/5913068.html 多线程在编程中有相当重要的地位,我们在实际开发时或者找工作面试时总能遇到多线程的问题,对 ...
- Raspberry install wine
sudo apt install wine winecfg出现问题 树莓派3B是卡片电脑,内存为1GB,一般运行Linux.Linux两种主流的内存分配方法2G/2G和3G/1G,树莓派系统后期优化性 ...
- 如何解决MSSQL中文数据乱码问题
今天遇到了在数据库中直接写SQL语句,语句中包含中文,但是数据库的表里是包含“?” 的乱码. 我程序代码中,调试时得到的SQL不是乱码,在控制台中也不是乱码.但是在数据库中却出现了乱码. 当用MSSQ ...
- linux下部署redis
基础知识: 1.Redis的数据类型: 字符串.列表(lists).集合(sets).有序集合(sorts sets).哈希表(hashs)2.Redis和memcache相比的独特之处: (1)re ...
- java抽象类,接口与异常
1.抽象类: 定义;包含一个抽象方法的类称称为抽象类,抽象类在class前使用adstract关键词修饰. 抽象方法;只声明未实现的方法称为抽象方法,使用adstract关键字声明该方法. 抽象类定义 ...
- ArcGIS的网络分析
ArcGIS的网络分析分为两类:传输网络(Network Analyst)和效用网络(Utility Network Analyst). 一.从应用上来考虑: 1.传输网络常用于道路.地铁等交通网络分 ...
- OC文件操作2
1.对文件本身的操作 NSManager 2.对文件内容的操作 NSHandle 文件句柄 NSFileHandle * fh = [NSFileHandle fileHandleForReading ...
- Homebrew 安装 MySQL
安装 Homebrew brew doctor 确认 brew 在正常工作 brew update 更新包 brew install mysql 安装 MySQL ==> Downloadi ...