885. 求组合数 I
给定 n 组询问,每组询问给定两个整数 a,b,请你输出 的值。
输入格式
第一行包含整数 n。
接下来 n 行,每行包含一组 a 和 b。
输出格式
共 n 行,每行输出一个询问的解。
数据范围
1≤n≤10000
1≤b≤a≤2000
输入样例:
33 15 32 2
输出样例:
3101
要素
- 10000组数据
- 1 <= b <= a <= 2000
- p = 1e9 + 7
直接用递推方法得出所有可能被询问的组合数结果,即杨辉三角
时间复杂度O(n2)
import java.util.*;public class Main {static final int MOD = 1000000007;static int n = 2010;static int[][] c = new int[n][n];static {for (int i = 0; i < n; i++) {for (int j = 0; j <= i; j++) {if (j == 0) c[i][j] = 1;else c[i][j] = (c[i-1][j] + c[i-1][j-1]) % MOD;}}}public static void main(String[] args) {Scanner sc = new Scanner(System.in);int m = sc.nextInt();while (m-- > 0) {int a = sc.nextInt(), b = sc.nextInt();System.out.println(c[a][b]);}}}
