[问题] 排列组合的疑问

楼主: ptt0720 (湿湿)   2017-06-07 16:21:32
def combos(n, m = 1):
if n < m:
return []
res = [[n]]
for i in range(m, n):
l = [i]
for j in combos(n - i, i):
res += [l + j]
return res
print (combos(5))
我写题目遇到一题 题目是这样
假如输入3 要列出所有相加等于3的情况
[3],[2,1],[1,1,1]
然后爬文看到一个算式比较简单的写法
但是还是不太懂
第七行为什么可以让循环在def执行?
还有他的每一层迭代我也不是很了解
目前只理解到 第一次执行会留下自己的值
接下来把自己的值-1 (ex:3-1=2) 继续分解2
假如输入是5呢
[5],[1,4],[1,1,3],[1,1,1,2],[1,1,1,1,1]
接下来的
[1,2,2],[2,3]是如何进行迭代的 我就不太清楚了
希望板上神人们可以指导一下
作者: zerof (猫橘毛发呆雕像)   2017-06-07 16:35:00
递回 return list
作者: s860134 (s860134)   2017-06-07 22:13:00
这种动态规划的真的很烧脑XD 学过还是很难实践
作者: ides13 (juso)   2017-06-07 22:28:00
第七行递回,刚学时也觉得奇怪,反正就是可以不用问为什么http://www.pythontutor.com/ 把code贴到这执行,看内存怎么被使用的,就可以了解了。不过,我试了还是不怎么懂要静下心来慢慢想。另外,5改成3吧,不然步骤太多了。刚刚看图时发现,function object是一开始就准备好了。进行for循环后,形成了3个combos再慢慢return。

Links booklink

Contact Us: admin [ a t ] ucptt.com