-
Notifications
You must be signed in to change notification settings - Fork 30
/
Copy pathNcR.java
executable file
·35 lines (27 loc) · 886 Bytes
/
NcR.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
import java.io.*;
import java.util.*;
import java.lang.*;
class DPnCr{
public static void main(String[] ss)throws Exception{
BufferedReader br=new BufferedReader(new InputStreamReader(System.in));
BufferedWriter out=new BufferedWriter(new OutputStreamWriter(System.out));
int tests=Integer.parseInt(br.readLine());
for(int t=0;t<tests;t++){
int n=Integer.parseInt(br.readLine());
int[] num=new int[n];
String[] s=br.readLine().split(" ");
for(int i=0;i<n;i++){
num[i]=Integer.parseInt(s[i]);
}
long [][] c=new long[20+1][20+1];
//n=20;c(20,r)
for(int i=0;i<=20;i++){c[i][i]=1;c[i][0]=c[0][i]=0;c[i][1]=i;}
for(int j=2;j<20;j++){
for(int i=j+1;i<=20;i++){
c[i][j]=c[i-1][j]+c[i-1][j-1];
}
}
for(int i=0;i<n;i++){out.write(""+c[20][num[i]]+"\n");out.flush();}
}
}
}