Java examples for java.lang:Math Calculation
Computes the binomial coefficient (number of unique ways to choose k elements from a set of n elements) by converting arguments from type long to type BigInteger.
//package com.java2s; import java.math.BigInteger; public class Main { public static final BigInteger ZERO = new BigInteger("0", 10); public static final BigInteger ONE = new BigInteger("1", 10); /**//from www. ja v a 2 s .c o m * Computes the binomial coefficient (number of unique ways to choose k elements from a set of n elements) by converting arguments from type long to type BigInteger. * @param n number of elements in the set * @param k number of elements to choose from the set * @return number of ways to choose k elements from n elements in the set */ public static BigInteger binomialCoefficientAsBigInteger(long n, long k) { return binomialCoefficient(new BigInteger(Long.toString(n), 10), new BigInteger(Long.toString(k), 10)); } /** * Computes the binomial coefficient (number of unique ways to choose k elements from a set of n elements) over BigIntegers. * @param n number of elements in the set * @param k number of elements to choose from the set * @return number of ways to choose k elements from n elements in the set */ public static BigInteger binomialCoefficient(BigInteger n, BigInteger k) { BigInteger result = ONE; if (k.compareTo(n) > 0) return ZERO; for (BigInteger i = ONE; i.compareTo(k) < 1; i = i.add(ONE)) { result = result.multiply(n); //result *= n--; n = n.subtract(ONE); result = result.divide(i); //result /= i; } return result; } /** * Computes the binomial coefficient (number of unique ways to choose k elements from a set of n elements). * @param n number of elements in the set * @param k number of elements to choose from the set * @return number of ways to choose k elements from n elements in the set */ public static long binomialCoefficient(long n, long k) { long result = 1; if (k > n) return 0; for (long i = 1; i <= k; i++) { result *= n--; result /= i; } return result; } /** * Represents an array of an array of ints (an int matrix) as a matrix style formatted string * @param a array of an array of ints to be formatted * @return a String representing the input array as a matrix */ public static String toString(int[][] a) { StringBuffer buf = new StringBuffer(); for (int i = 0; i < a.length; i++) { for (int j = 0; j < a[i].length; j++) { buf.append(a[i][j]); buf.append(" "); } buf.replace(buf.length() - 1, buf.length(), "\n"); } return buf.substring(0, buf.length() - 1); } }