洛谷 P3834 卢卡斯定理 题解
首先你需要知道这条定理:
C(n,m)=C(n%p,m%p)*C(n/p,m/p);
这样可以递归实现;
注意坑点:是C(n+m,m),并不是C(n,m);
#include <bits/stdc++.h>
using namespace std;
long long n,m,p;
inline long long KSM(long long a,long long b)
{
long long res=;
while(b){
if(b&) res=res*a%p;
a=a*a%p;
b/=;
}
return res%p;
}
long long C(long long n,long long m)
{
if(n<m) return ; //并不是返回1;
long long res1=,res2=;
for(register int i=(n-m+);i<=n;i++){
res1=res1*i%p;
}
for(register int i=;i<=m;i++){
res2=res2*i%p;
}
return res1*KSM(res2,p-)%p;
}
long long LUCAS(long long n,long long m)
{
if(m==){
return ;
}
return C(n%p,m%p)*LUCAS(n/p,m/p)%p;
}
int main ()
{
int t;
cin>>t;
while(t--)
{
cin>>n>>m>>p;
cout<<LUCAS(n+m,m)<<endl;
}
}
洛谷 P3834 卢卡斯定理 题解的更多相关文章
- 洛谷p1586四方定理题解
		题目 这个题的本质是动态规划中的背包问题. 为什么会想到背包呢. 因为往往方案数不是排列组合就是递推或者是dp,当然还有其他的可能.我们可以把一个数的代价当成这个数的平方,价值就是一个方案数.由于这个 ... 
- 洛谷P2832 行路难 分析+题解代码【玄学最短路】
		洛谷P2832 行路难 分析+题解代码[玄学最短路] 题目背景: 小X来到了山区,领略山林之乐.在他乐以忘忧之时,他突然发现,开学迫在眉睫 题目描述: 山区有n座山.山之间有m条羊肠小道,每条连接两座 ... 
- 【洛谷P3960】列队题解
		[洛谷P3960]列队题解 题目链接 题意: Sylvia 是一个热爱学习的女孩子. 前段时间,Sylvia 参加了学校的军训.众所周知,军训的时候需要站方阵. Sylvia 所在的方阵中有 n×m ... 
- 洛谷P2312 解方程题解
		洛谷P2312 解方程题解 题目描述 已知多项式方程: \[a_0+a_1x+a_2x^2+\cdots+a_nx^n=0\] 求这个方程在 \([1,m]\) 内的整数解(\(n\) 和 \(m\) ... 
- 洛谷P1577 切绳子题解
		洛谷P1577 切绳子题解 题目描述 有N条绳子,它们的长度分别为Li.如果从它们中切割出K条长度相同的 绳子,这K条绳子每条最长能有多长?答案保留到小数点后2位(直接舍掉2为后的小数). 输入输出格 ... 
- 洛谷P2507 [SCOI2008]配对 题解(dp+贪心)
		洛谷P2507 [SCOI2008]配对 题解(dp+贪心) 标签:题解 阅读体验:https://zybuluo.com/Junlier/note/1299251 链接题目地址:洛谷P2507 [S ... 
- 洛谷 P1220 关路灯 题解
		Description 有 $n$ 盏路灯,每盏路灯有坐标(单位 $m$)和功率(单位 $J$).从第 $c$ 盏路灯开始,可以向左或向右关闭路灯.速度是 $1m/s$.求所有路灯的最少耗电.输入保证 ... 
- 【洛谷P3410】拍照题解(最大权闭合子图总结)
		题目描述 小B有n个下属,现小B要带着一些下属让别人拍照. 有m个人,每个人都愿意付给小B一定钱让n个人中的一些人进行合影.如果这一些人没带齐那么就不能拍照,小B也不会得到钱. 注意:带下属不是白带的 ... 
- [BZOJ 3039&洛谷P4147]玉蟾宫 题解(单调栈)
		[BZOJ 3039&洛谷P4147]玉蟾宫 Description 有一天,小猫rainbow和freda来到了湘西张家界的天门山玉蟾宫,玉蟾宫宫主蓝兔盛情地款待了它们,并赐予它们一片土地. ... 
随机推荐
- Python内置类属性
			__dict__ : 类的属性(包含一个字典,由类的数据属性组成) __doc__ :类的文档字符串 __name__: 类名 __module__: 类定义所在的模块(类的全名是'__main__. ... 
- idea 导入(非maven)web项目并发布到tomcat服务器
			IDEA 2017.1版本 web项目导入并发布到Tomcat服务器 1.点击编辑项目结构 2.点击project 将项目编译输出目录改成{项目目录}/OUT,并设置项目环境,编译版本 3.点击mod ... 
- AtCoder AGC017C Snuke and Spells
			题目链接 https://atcoder.jp/contests/agc017/tasks/agc017_c 题解 很久前不会做看了题解,现在又看了一下,只想说,这种智商题真的杀我... 转化成如果现 ... 
- 利用H5缓存机制实现点击按钮第一次与之后再点击分别跳转不同页面
			昨天碰到这样一个需求,要求点击按钮第一次跳转到a页面,之后再点击它就跳转到b页面.这个问题我首先就想到了利用H5的缓存sessionstorage来实现,SessionStorage用于本地存储一个会 ... 
- 高性能JavaScript之加载和执行
			JS在浏览器中的性能,可以认为是开发者所面临的最重要的可行性问题.这个问题因JS的阻塞特性变得复杂,也就是说当浏览器在执行JS代码时,不能同时做其他任何事情.事实上,大多数浏览器都使用单一进程来处理U ... 
- awk命令2
			提取文件后四行 注释:NR==FNR表示第一个文件,执行{a++},计算出第一个文件10的行数,NR!=FNR表示第二个文件10,执行{if(FNR<=a-4){print $0}},打印出第二 ... 
- AOP 代理类的创建
			AOP 代理类的创建 入口:AnnotationAwareAspectJAutoProxyCreator#postProcessAfterInitialization 和 AnnotationAwar ... 
- MySQL 树形结构 根据指定节点 获取其所有叶子节点
			背景说明 需求:MySQL树形结构, 根据指定的节点,获取其下属的所有叶子节点. 叶子节点:如果一个节点下不再有子节点,则为叶子节点. 问题分析 1.可以使用类似Java这种面向对象的语言,对节点集合 ... 
- Python实现利用最大公约数求三个正整数的最小公倍数示例
			Python实现利用最大公约数求三个正整数的最小公倍数示例 本文实例讲述了Python实现利用最大公约数求三个正整数的最小公倍数.分享给大家供大家参考,具体如下: 在求解两个数的小公倍数的方法时,假设 ... 
- k8s中使用harbor
			参考地址:https://www.cnblogs.com/wayneiscoming/p/7716238.html .在harbor的ui界面上注册一个账号 姓名:zihao 全名:zhuzihao ... 
