我正在编写嵌套的while循环,这些循环越来越不切实际(> 12个嵌套循环),我该如何递归编码?

前端之家收集整理的这篇文章主要介绍了我正在编写嵌套的while循环,这些循环越来越不切实际(> 12个嵌套循环),我该如何递归编码? 前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

我有一些代码本质上会增加一个非常大的数字,我有一些python代码可以很好地处理较小的数字.

def test_loop():

    base = 3

    # increment number
    for a in range(0,2):
        b = a

        while b < base:
            c = b

            while c < base:
                d = c

                while d < base:

                    n = (d + c*base**1 + b*base**2 + a*base**3)
                    print n

                    d += 1
                c += 1
            b += 1

这会打印出我想要的数字列表,以基数3表示时,最长为4位数字.
我实际上需要增加20位长数字,并且我编写的嵌套while循环越来越嵌套的代码.我相信Python在可以嵌套多少层上有一个限制,但是使用递归还必须有更好的方法吗?

结果示例
0
1个
2
4
5
8
13
14
17
26
40
41
44
53

最佳答案
没错,Python中嵌套的for循环是有限制的.我认为大约是20,所以您的解决方案无法正常工作.但是,即使限制更大,您仍希望使用递归使代码更清晰,简洁和灵活.递归可以解决您的问题的方法如下:

def list_special_numbers(base,digits,starting_digit=0,partial_sum=0):
    if digits == 1:
        for i in range(starting_digit,base):
            print(partial_sum + i)
    else:
        for i in range(starting_digit,base):
            list_special_numbers(base,digits-1,i,partial_sum + i*(base**(digits-1)))

# *** Usage examples ***

# print the list of desired numbers up to 20-ternary-digit numbers
list_special_numbers(3,20)

# print the list of desired numbers up to 30-ternary-digit numbers
list_special_numbers(3,30)

# print the list of desired numbers up to 30-binary-digit numbers
list_special_numbers(2,30)

# print the list of desired numbers up to 3-decimal-digit numbers
list_special_numbers(10,3)

猜你在找的Python相关文章