N嵌套的python循环

2024-09-28 05:17:11 发布

您现在位置:Python中文网/ 问答频道 /正文

有没有办法像反序函数那样拥有动态的循环数? 字母是字符['a','b','c','d']和 letterdict是一本字典{'a':['b','c'],'b':['a'],'c':['d'],'d':['b','c','d'] 我的代码是n=13的:

for x in letters:
    for k1 in letterdict[x]:
        for k2 in letterdict[k1]:
            for k3 in letterdict[k2]:
                for k4 in letterdict[k3]:
                    for k5 in letterdict[k4]:
                        for k6 in letterdict[k5]:
                            for k7 in letterdict[k6]:
                                for k8 in letterdict[k7]:
                                    for k9 in letterdict[k8]:
                                        for k10 in letterdict[k9]:
                                            for k11 in letterdict[k10]:
                                                for k12 in letterdict[k11]:
                                                    for k13 in letterdict[k12]:
                                                        word=""
                                                        word=x+k1+k2+k3+k4+k5+k6+k7+k8+k9+k10+k11+k12+k13
                                                        print(word)

但我希望n个循环使用相同的代码 像这样:

对于n=3

for x in letters:
    for k1 in letterdict[x]:
        for k2 in letterdict[k1]:
            for k3 in letterdict[k2]:
                word=""
                word=x+k1+k2+k3
                print(word)

Tags: infork2k1wordk3k5k4
1条回答
网友
1楼 · 发布于 2024-09-28 05:17:11

通常,当您发现自己需要无限多个嵌套循环时,应该编写一个递归函数。以下是作为生成器函数的实现:

def generate_strings(letters, transitions, k):
    def helper(s):
        if len(s) == k:
            yield s
        elif len(s) < k:
            for letter in transitions[s[-1]]:
                yield from helper(s + letter)
    for letter in letters:
        yield from helper(letter)

示例:请注意,您不必使用字符列表,因为字符串也是字符序列

>>> letters = 'abcd'
>>> transitions = {'a': 'bc', 'b': 'a', 'c': 'd', 'd': 'bcd'}
>>> for s in generate_strings(letters, transitions, 4):
...     print(s)
... 
abab
abac
acdb
acdc
acdd
baba
bacd
cdba
cdcd
cddb
cddc
cddd
dbab
dbac
dcdb
dcdc
dcdd
ddba
ddcd
dddb
dddc
dddd

相关问题 更多 >

    热门问题