我正在尝试学习 Python 3.x 的动态编程和递归。下面的代码是我教科书中的一个简单示例:
def recMC(coinValueList, change):
minCoins = change
if change in coinValueList:
return 1
else:
for i in [c for c in coinValueList if c <= change]:
numCoins = 1 + recMC(coinValueList, change-i)
if numCoins < minCoins:
minCoins = numCoins
return minCoins
print(recMC([1,5,10,25], 63))
我真的很难理解这里的第 6 行,即行理解。我完全不确定这里发生了什么,以及如何将其分解为循环以便更容易理解。这是我目前的想法:
for i in c:
for c in coinValueList:
if c<= change:
但我不明白这是如何迭代的。也许知识渊博的人可以用与我的书和教授不同的方式来解释这一点?