AcWing算法基础课笔记——求组合数3

求组合数Ⅲ

20万组数据, 1 ≤ b ≤ a ≤ 1 0 18 , 1 ≤ p ≤ 1 0 5 1 \le b \le a \le 10^{18}, 1\le p \le 10 ^5 1≤b≤a≤1018,1≤p≤105,使用卢卡斯定理。

卢卡斯定理:
C a b ≡ C a m o d p b m o d p C a / p b / p ( m o d p ) C_a^b \equiv C_{a mod p}^{b mod p}C_{a /p}^{b / p} (mod p) Cab≡CamodpbmodpCa/pb/p(modp)

时间复杂度为 O ( l o g p N ⋅ p l o g p ) O(log _p N \cdot plogp) O(logpN⋅plogp)

题目

代码

cpp 复制代码
#include<iostream>
#include<algorithm>

using namespace std;

typedef long long LL;

int p;

int qmi(int a, int k){
	int res = 1;
	while(k) {
		if(k & 1) res = (LL) res * a % p;
		a = (LL) a * a % p;
		k >>= 1;
	}
	return res;
}

int C(int a, int b) {
	int res = 1;
	for(int i = 1, j = a; i <= b; i ++, j --) {
		res = (LL) res * j % p;
		res = (LL) res * qmi(i, p - 2) % p;
	}
	return res;
}

int lucas(LL a, LL b) {
	if(a < p && b < p) return C(a, b);
	return (LL)C(a % p, b % p) * lucas(a / p, b / p) % p;
}

int main() {
	int n;
	cin >> n;
	while(n -- ) {
		LL a, b;
		cin >> a >> b >> p;
		cout << lucas(a, b) << endl;
	}
	return 0;
}
相关推荐
椰萝Yerosius13 分钟前
[题解]2024CCPC郑州站——Z-order Curve
c++·算法
小曹要微笑16 分钟前
STM32F7 时钟树简讲(快速入门)
c语言·stm32·单片机·嵌入式硬件·算法
南山安25 分钟前
栈(Stack):从“弹夹”到算法面试题的进阶之路
javascript·算法·面试
2301_764441331 小时前
Python构建输入法应用
开发语言·python·算法
love530love1 小时前
【笔记】ComfUI RIFEInterpolation 节点缺失问题(cupy CUDA 安装)解决方案
人工智能·windows·笔记·python·插件·comfyui
愚戏师1 小时前
MySQL 数据导出
数据库·笔记·mysql
AI科技星1 小时前
为什么变化的电磁场才产生引力场?—— 统一场论揭示的时空动力学本质
数据结构·人工智能·经验分享·算法·计算机视觉
摇滚侠2 小时前
2025最新 SpringCloud 教程,教程简介,笔记01
笔记·spring cloud
TheLegendMe2 小时前
贪心+线程安全单例
算法·哈希算法
豐儀麟阁贵3 小时前
8.5在方法中抛出异常
java·开发语言·前端·算法