首页 > 编程语言 >AcWing算法基础课笔记——求组合数2

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

时间:2024-06-23 10:59:16浏览次数:23  
标签:10 infact int LL 算法 基础课 AcWing fact mod

求组合数Ⅱ

1万组数据, 1 ≤ b ≤ a ≤ 1 0 5 1 \le b \le a \le 10^5 1≤b≤a≤105,预处理阶乘。时间复杂度 O ( N l o g N ) O(NlogN) O(NlogN)
C a b = a ! ( b − a ) ! b ! C_a^b = \frac{a !}{(b - a)! b!} Cab​=(b−a)!b!a!​
预处理出 i ! i ! i!和 ( i ! ) − 1 (i !)^{-1} (i!)−1
f a c t [ i ] = i ! m o d ( 1 0 9 + 7 ) i n f a c t [ i ] = ( i ! ) − 1 fact[i] = i ! mod (10^9 + 7) \\ infact[i] = (i!)^{-1} fact[i]=i!mod(109+7)infact[i]=(i!)−1
因此
C a b = f a c t [ a ] × i n f a c t [ b − a ] × i n f a c t [ b ] C_a^b = fact[a] \times infact[b - a] \times infact[b] Cab​=fact[a]×infact[b−a]×infact[b]

题目

题目描述:

给定n组询问,每组询问给定两个整数a,b,请你输出C(a,b) mod (10^9+7)的值。

输入格式

第一行包含整数n。接下来n行,每行包含一组a和b。

输出格式

共n行,每行输出一个询问的解。

数据范围

1≤n≤100000,1≤b≤a≤10^5

输入样例:

3
3 1
5 3
2 2

输出样例:

3
10
1

代码

#include<iostream>
using namespace std;

typedef long long LL;
const int N = 100010, mod = 1e9 + 7;

int fact[N], infact[N];

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

int main() {
	fact[0] = infact[0] = 1;
	for(int i = 1; i < N; i ++ ) {
		fact[i] = (LL)fact[i - 1] * i % mod;
		infact[i] = (LL)infact[i - 1] * qmi(i, mod - 2, mod) % mod;
	}
	
	int n;
	scanf("%d", &n);
	while(n -- ) {
		int a, b;
		scanf("%d%d", &a, &b);
		printf("%d\n", (LL)fact[a] * infact[b] % mod * infact[a - b] % mod);
	}
	
	return 0;
}

标签:10,infact,int,LL,算法,基础课,AcWing,fact,mod
From: https://blog.csdn.net/Sophia2021XJTU/article/details/139897074

相关文章

  • 【昆虫识别系统】图像识别Python+卷积神经网络算法+人工智能+深度学习+机器学习+Tenso
    一、介绍昆虫识别系统,使用Python作为主要开发语言。通过TensorFlow搭建ResNet50卷积神经网络算法(CNN)模型。通过对10种常见的昆虫图片数据集('蜜蜂','甲虫','蝴蝶','蝉','蜻蜓','蚱蜢','蛾','蝎子','蜗牛','蜘蛛')进行训练,得到一个识别精度较......
  • 机器学习各个算法的优缺点!(上篇) 建议收藏。
      下篇地址:机器学习各个算法的优缺点!(下篇)建议收藏。-CSDN博客.......纯干货..........回归正则化算法集成算法决策树算法支持向量机降维算法聚类算法贝叶斯算法人工神经网络深度学习感兴趣的朋友可以点赞、转发起来,让更多的朋......
  • Transformers是SSMs:通过结构化状态空间对偶性的广义模型和高效算法(一)
    文章目录摘要1、引言2、背景与概述2.1、结构化状态空间模型2.2、注意力机制2.3、结构化矩阵2.4、概述:结构化状态空间对偶性2.5、符号3、状态空间模型是结构化矩阵3.1、状态空间模型的矩阵变换形式3.2、半可分离矩阵3.2.1、顺序半可分离(SSS)表示3.2.2、1-半可分矩阵:标量SS......
  • 算法金 | 统计学的回归和机器学习中的回归有什么差别?
    大侠幸会,在下全网同名「算法金」0基础转AI上岸,多个算法赛Top「日更万日,让更多人享受智能乐趣」统计学中的回归目标:主要用于解释和推断自变量(independentvariables)和因变量(dependentvariables)之间的关系。强调模型的解释性,了解各个自变量对因变量的影响。假设:......
  • 基于鲸鱼优化的knn分类特征选择算法matlab仿真
    1.程序功能描述       基于鲸鱼优化的KNN分类特征选择算法。使用鲸鱼优化算法,选择最佳的特征,进行KNN分类,从而提高KNN分类的精度。 2.测试软件版本以及运行结果展示MATLAB2022a版本运行    3.核心程序  %---开始迭代-------------------------------......
  • x-s、x-t、x-s-common、x-b3-traceid 签名算法分析记录(2024/6/20)
    【作者主页】:小鱼神1024【擅长领域】:JS逆向、小程序逆向、AST还原、验证码突防、Python开发、浏览器插件开发、React前端开发、NestJS后端开发等等【学习交流】:知识星球:https://t.zsxq.com/gkn0r;vx:studypy1024本文章中所有内容仅供学习交流使用,不用于其他任何目的,不提......
  • AcWing算法基础课笔记——求组合数1
    求组合数Ⅰ10万组数据,1≤b≤a≤2000......
  • AcWing 5726. 连续子序列
    5726.连续子序列-AcWing题库01trie的不错的练习题。题目说了求一段连续子序列的异或和,因为异或有结合律,所以我们可以直接预处理一个前缀异或和,即\(a[l,r]=sum[r]\operatorname{xor}sum[l-1]\)。然后求一段异或和就变成了求任意两个\(sum\)的异或和,而这就可以用到0......
  • C++ STL容器操作:6种常用场景算法
    C++STL容器操作:6种常用场景算法    •   引言   •   概述   •   查找与计数   ▪   std::find   ▪   std::find_if   ▪   std::find_if_not   ▪   std::find_end   ▪   std::find_first_of......
  • C语言程序设计-2 程序的灵魂—算法
    【例2.1】求1×2×3×4×5。最原始方法:步骤1:先求1×2,得到结果2。步骤2:将步骤1得到的乘积2乘以3,得到结果6。步骤3:将6再乘以4,得24。步骤4:将24再乘以5,得120。这样的算法虽然正确,但太繁。改进的算法:S1:使t=1S2:使i=2S3:使t×i,乘积仍然......