Understanding change-making algorithm

To get all possible sets that elements are equal to ‘a’ or ‘b’ or ‘c’ (our coins) that sum up to ‘X’ you can:

  • Take all such sets that sum up to X-a and add an extra ‘a’ to each one.
  • Take all such sets that sum up to X-b and add an extra ‘b’ to each one.
  • Take all such sets that sum up to X-c and add an extra ‘c’ to each one.

So number of ways you can get X is sum of numbers of ways you can get X-a and X-b and X-c.

ways[i]+=ways[i-coin]

Rest is simple recurrence.

Extra hint:
at the start you can get set with sum zero in exactly one way (empty set)

ways = [1]+[0]*target

Leave a Comment