欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 汽车 > 新车 > AcWing算法基础课笔记——求组合数2

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

2024/10/24 1:50:05 来源:https://blog.csdn.net/Sophia2021XJTU/article/details/139897074  浏览:    关键词:AcWing算法基础课笔记——求组合数2

求组合数Ⅱ

1万组数据, 1 ≤ b ≤ a ≤ 1 0 5 1 \le b \le a \le 10^5 1ba105,预处理阶乘。时间复杂度 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=(ba)!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[ba]×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;
}

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com