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. - Java java.lang

Java examples for java.lang:Math Calculation

Description

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.

Demo Code


//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);
    }
}

Related Tutorials