【发布时间】:2021-04-01 04:58:01
【问题描述】:
我这里有一个代码
letters = ['a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z']
ret = ""
for i in range(26):
for j in letters:
ret += f"({letters[i]},{j})"
print(ret)
#Output:
(a,a)(a,b)(a,c)(a,d)(a,e)(a,f)(a,g)(a,h)(a,i)(a,j)(a,k)(a,l)(a,m)(a,n)(a,o)(a,p)...(z,y)(z,z)
我要解决的问题是:
当我试图增加排列的数量时,例如从 2 位数到 3 位数,我必须添加另一个循环。如何在增加位数时增加循环数,当我想将其实现为函数时,任何人都可以帮忙:(
这是我尝试将位数从 2 增加到 3 时所做的:
for i in range(26):
for k in range(26):
for j in letters:
ret += "(" + str(letters[i]) + "," + str(letters[k]) + "," + j + ")"
print(ret)
#Output
(a,a,a)(a,a,b)(a,a,c)(a,a,d)(a,a,e)(a,a,f)(a,a,g)(a,a,h)(a,a,i)(a,a,j)(a,a,k)(a,a,l)(a,a,m)...(z,z,z)
如何在函数中实现这一点?
【问题讨论】:
-
查看
itertools.product(您要的是笛卡尔积,而不是排列,尽管 itertools 将同时拥有更多...) -
正如Julien所说,可以参考python的itertools源码。它们非常清晰整洁。例如,您的问题的答案可以在这里找到:docs.python.org/3/library/itertools.html#itertools.product。
标签: python function loops permutation