【问题标题】:How to increase number of loops in a function?如何增加函数中的循环数?
【发布时间】: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


【解决方案1】:

您可以像这样使用 itertools 来实现这一点

import itertools

def perm_func(arr, x):
    ret_str = ""
    p for p in itertools.product(arr, repeat=x):
        ret_str += str(p)

    return ret_str

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2017-06-19
    • 2018-06-11
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多