亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

在python中制作遞歸函數

在python中制作遞歸函數

慕哥9229398 2021-03-30 13:11:07
這是一個作業問題。我嘗試獲得一個遞歸函數:def problem_a(n):    answer.append(n)    if n == 1:        return answer        elif n % 2 == 0:        answer.append(n/2)    else :        answer.append(n*3 + 1)        problem_a(n*3 + 1)顯然,此代碼不起作用,因為answer未定義為列表。使用循環可以正常工作,但是我想創建一個遞歸函數。我可以只使用一個列表作為輸入,但是我想知道是否存在更優雅的東西。problem_a(7) 應該給出作為輸出:[7, 22, 11, 34, 17, 52, 26, 13, 40 , 20, 10 ,5 ,16, 8, 4, 2, 1]
查看完整描述

3 回答

?
人到中年有點甜

TA貢獻1895條經驗 獲得超7個贊

到目前為止,已經提出的方法(使用額外的參數將列表傳遞到遞歸鏈中)的一種替代解決方案是在您從遞歸返回時構建最終列表。這并不是非常有效,因為連接列表需要同時復制它們,但是它可以工作:


def problem_a(n):

    if n == 1:

        return [n]

    elif n % 2 == 0:

        return [n] + problem_a(n // 2)

    else:

        return [n] + problem_a(3*n + 1)



查看完整回答
反對 回復 2021-04-02
?
四季花海

TA貢獻1811條經驗 獲得超5個贊

您可以定義局部變量answer,然后在遞歸調用中傳遞它。


def problem_a(n, answer = None):

    answer = [n] if answer is None else answer

    if n == 1:

        return answer

    elif n % 2 == 0:

        n = n/2

        answer.append(n)

    else:

        n = n*3 + 1

        answer.append(n)

    return problem_a(n, answer)


print problem_a(7)        

輸出:


[7, 22, 11, 34, 17, 52, 26, 13, 40, 20, 10, 5, 16, 8, 4, 2, 1]


查看完整回答
反對 回復 2021-04-02
?
胡說叔叔

TA貢獻1804條經驗 獲得超8個贊

您可以嘗試使用發電機:


def problem_a(n):

    yield n

    if n == 1:

        return

    elif n % 2 == 0:

        x = n / 2

    else:

        x = n * 3 + 1


    for y in problem_a(x):

        yield y


print list(problem_a(7))


查看完整回答
反對 回復 2021-04-02
  • 3 回答
  • 0 關注
  • 256 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號