簡體   English   中英

如何從Python的遞歸函數返回列表?

[英]How to return a list from a recursive function in Python?

我有以下代碼:

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

調用代碼將輸出為None:

>>> primes(10)
None

您需要再次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

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM