为什么print()函数在这种情况下不打印

时间:2017-09-03 22:08:11

标签: python-3.x recursion printing nonetype

我一直在研究一个问题,我不明白为什么递归函数步骤返回None?

这是代码:

import sys

def minIndx(list):
    x=10
    indx=0
    for i in range(len(list)):
        if (list[i]<x):
            x=list[i]
            indx=i
    return indx

def steps(arr,sum1,sum2,x):
    i = minIndx(arr)
    del arr[i]
    sum1 = sum(arr)
    if (sum1 + 9*x >= sum2):
        return x
    else: steps(arr,sum1,sum2,x+1)

s=input()
digits1=[]
digits2=[]
for i in range(len(s)):
    if (i>2):break
    digits1.append(int(s[i]))
for i in range(len(s)):
    if (i<3):continue
    digits2.append(int(s[i]))
sumLeft = sum(digits1)
sumRight = sum(digits2)
print(steps(digits1,sumLeft,sumRight,1))

测试用例:123456, 步骤功能打印无以及打印功能

1 个答案:

答案 0 :(得分:1)

可能是因为您没有返回递归通话。你的预期产量是多少?当我将递归调用返回到步骤时,我得到一个值为2的输入123456。