/** * * @author Varun Upadhyay (https://github.com/varunu28) * */ public class CoinChange { // Driver Program public static void main(String[] args) { int amount = 12; int[] coins = {2, 4, 5}; System.out.println("Number of combinations of getting change for " + amount + " is: " + change(coins, amount)); System.out.println("Minimum number of coins required for amount :" + amount + " is: " + minimumCoins(coins, amount)); } /** * This method finds the number of combinations of getting change for a given amount and change coins * * @param coins The list of coins * @param amount The amount for which we need to find the change * Finds the number of combinations of change **/ public static int change(int[] coins, int amount) { int[] combinations = new int[amount+1]; combinations[0] = 1; for (int coin : coins) { for (int i=coin; i