我有一些代码本质上会增加一个非常大的数字,我有一些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
@H_502_8@这会打印出我想要的数字列表,以基数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)
@H_502_8@