3 回答

TA貢獻(xiàn)1765條經(jīng)驗(yàn) 獲得超5個(gè)贊
當(dāng)前的實(shí)現(xiàn)有兩個(gè)基本問(wèn)題:
c
是 anint
,并且int
s 是不可變的。如果更改c
,因此,這也并不意味著c
在遞歸調(diào)用的“更新”,每次遞歸調(diào)用c
將具有價(jià)值0
; 和如果第一項(xiàng)是偶數(shù),則不會(huì)返回值,因此
None
在這種情況下Python 將返回。
def count_even(lst, c = 0):
if lst == []:
return c
if lst[0] % 2 == 0:
c += 1
# no else
return count_even(lst[1:], c+1) # pass a new value for c
然而,更緊湊的表示是:
def count_even(lst, c = 0):
if not lst:
return c
return count_even(lst[1:], c + 1 - lst[0] % 2)
但是請(qǐng)注意,線性遞歸通常不是一個(gè)好主意,因?yàn)檎{(diào)用堆棧會(huì)隨著元素?cái)?shù)量的增加而增長(zhǎng),因此很容易導(dǎo)致溢出(尤其是因?yàn)?Python 沒(méi)有實(shí)現(xiàn)尾調(diào)用優(yōu)化 (TCO))。

TA貢獻(xiàn)2012條經(jīng)驗(yàn) 獲得超12個(gè)贊
萬(wàn)一lst[0] % 2 == 0,您沒(méi)有返回任何內(nèi)容(因此隱式返回None)。您也永遠(yuǎn)不會(huì)c在遞歸中包含 的更新值。將其更改為
if lst == []:
return c
if lst[0] % 2 == 0:
c += 1
return count_even(lst[1:], c)
你很好。由于其他答案包括一些漂亮的替代解決方案,我將繼續(xù)提名
def count_even(lst):
return 1 - lst[0]%2 + count_even(lst[1:]) if lst else 0
以及。

TA貢獻(xiàn)1809條經(jīng)驗(yàn) 獲得超8個(gè)贊
你幾乎做到了。只是一個(gè)簡(jiǎn)單的修正。您正在調(diào)用 else 塊中的遞歸,這是不正確的。您應(yīng)該在塊之外考慮它。檢查以下代碼:
def count_even(lst, c = 0):
"""
parameters : a lst of type list
returns : the even elements from that list
"""
if lst == []:
return c
if lst[0] % 2 == 0:
c = c + 1
return c + count_even(lst[1:])
print(count_even([1,2,3,4,5,6,7,8,9]))
添加回答
舉報(bào)