886. 求组合数 II
// 886. 求组合数 II.cpp : 此文件包含 "main" 函数。程序执行将在此处开始并结束。
//
/*
https://www.acwing.com/problem/content/888/
给定 n 组询问,每组询问给定两个整数 a,b,请你输出 Cbamod(109+7) 的值。
输入格式
第一行包含整数 n。
接下来 n 行,每行包含一组 a 和 b。
输出格式
共 n 行,每行输出一个询问的解。
数据范围
1≤n≤10000,
1≤b≤a≤105
输入样例:
3
3 1
5 3
2 2
输出样例:
3
10
1
*/
#include <iostream>
using namespace std;
const int N = 100010;
const int M = 1e9 + 7;
long long fact[N];
long long infact[N];
int n;
long long qmi(long long a, long long b, long long MOD) {
long long ret = 1;
while (b != 0) {
if (b & 1) {
ret *= a;
ret %= MOD;
}
b >>= 1;
a *= a; a %= MOD;
}
return ret;
}
void init() {
fact[0] = 1;
infact[0] = 1;
for (int i = 1; i < N; i++) {
fact[i] = fact[i - 1] * i % M;
infact[i] = infact[i - 1] * qmi(i, M - 2, M) % M;
}
}
int main()
{
cin >> n;
init();
for (int i = 0; i < n; i++) {
int a, b; cin >> a >> b;
if (a >= b)
cout << fact[a] * infact[a - b] % M * infact[b] % M << endl;
}
return 0;
}
作 者: itdef
欢迎转帖 请保持文本完整并注明出处
技术博客 http://www.cnblogs.com/itdef/
B站算法视频题解
https://space.bilibili.com/18508846
qq 151435887
gitee https://gitee.com/def/
欢迎c c++ 算法爱好者 windows驱动爱好者 服务器程序员沟通交流
如果觉得不错,欢迎点赞,你的鼓励就是我的动力
欢迎转帖 请保持文本完整并注明出处
技术博客 http://www.cnblogs.com/itdef/
B站算法视频题解
https://space.bilibili.com/18508846
qq 151435887
gitee https://gitee.com/def/
欢迎c c++ 算法爱好者 windows驱动爱好者 服务器程序员沟通交流
如果觉得不错,欢迎点赞,你的鼓励就是我的动力

