我有以下代码:
def primes(n):
acc = []
return do_primes(range(2,n,1), acc)
def do_primes(xs, acc):
if xs:
head, tail = xs[0], xs[1:]
acc.append(head)
do_primes([x for x in xs if x % head != 0], acc)
else:
return acc
调用代码会产生无:
>>> primes(10)
None
答案 0 :(得分:4)
您需要再次return
:
def do_primes(xs, acc):
if xs:
head, tail = xs[0], xs[1:]
acc.append(head)
return do_primes([x for x in xs if x % head != 0], acc)
else:
return acc