2020-08-16 19:58:48 +08:00
|
|
|
package Maths;
|
|
|
|
|
2020-10-24 18:23:28 +08:00
|
|
|
/** @see <a href="https://en.wikipedia.org/wiki/Combination">Combination</a> */
|
2020-08-16 19:58:48 +08:00
|
|
|
public class Combinations {
|
2020-10-24 18:23:28 +08:00
|
|
|
public static void main(String[] args) {
|
|
|
|
assert combinations(1, 1) == 1;
|
|
|
|
assert combinations(10, 5) == 252;
|
|
|
|
assert combinations(6, 3) == 20;
|
|
|
|
assert combinations(20, 5) == 15504;
|
|
|
|
}
|
2020-08-16 19:58:48 +08:00
|
|
|
|
2020-10-24 18:23:28 +08:00
|
|
|
/**
|
|
|
|
* Calculate of factorial
|
|
|
|
*
|
|
|
|
* @param n the number
|
|
|
|
* @return factorial of given number
|
|
|
|
*/
|
|
|
|
public static long factorial(int n) {
|
|
|
|
if (n < 0) {
|
|
|
|
throw new IllegalArgumentException("number is negative");
|
2020-08-16 19:58:48 +08:00
|
|
|
}
|
2020-10-24 18:23:28 +08:00
|
|
|
return n == 0 || n == 1 ? 1 : n * factorial(n - 1);
|
|
|
|
}
|
2020-08-16 19:58:48 +08:00
|
|
|
|
2020-10-24 18:23:28 +08:00
|
|
|
/**
|
|
|
|
* Calculate combinations
|
|
|
|
*
|
|
|
|
* @param n first number
|
|
|
|
* @param k second number
|
|
|
|
* @return combinations of given {@code n} and {@code k}
|
|
|
|
*/
|
|
|
|
public static long combinations(int n, int k) {
|
|
|
|
return factorial(n) / (factorial(k) * factorial(n - k));
|
|
|
|
}
|
2020-08-16 19:58:48 +08:00
|
|
|
}
|