在 Python 中编写程序,查找使用印度货币面额时,总面值为 n 的 R.s 有多少种方法
假设我们有面额为 ₹1、₹2、₹5 和 ₹10 的限量硬币。我们要找到用这些硬币将它们相加总面值为 ₹n 的方法有多少种?我们有一个大小为 4 的 count 数组,其中 count[0] 表示 ₹1 的硬币数量,count[1] 表示 ₹2 的硬币数量,以此类推。
因此,如果输入为 n = 25,count = [7, 3, 2, 2],则输出将为 9。
为了解决这个问题,我们将按照以下步骤进行:
- denom := [1,2,5,10]
- A := 长度为(n + 1)的数组,其中所有元素设置为 0
- B := A 的新列表
- for i in range 0 to (count[0] 和 n 中最小的值), do
- A[i] := 1
- for i in range 1 to 3, do
- for j in range 0 to count[i], do
- for k in range 0 to n + 1 – j * denom[i], do
- B[k + j * denom[i]] := B[k + j * denom[i]] + A[k]
- for j in range 0 to n, do
- A[j] := B[j]
- B[j] := 0
- for j in range 0 to count[i], do
- 返回 A[n]
示例
让我们看以下实现,以更好地理解: