Rumah > pembangunan bahagian belakang > Tutorial Python > Mengapa Fungsi Rekursif Python Saya Tidak Kembali?

Mengapa Fungsi Rekursif Python Saya Tidak Kembali?

Barbara Streisand
Lepaskan: 2024-11-02 14:34:30
asal
604 orang telah melayarinya

Why Does My Python Recursive Function Return None?

Mengapa Fungsi Rekursif Python Mengembalikan Tiada

Dalam Python, fungsi rekursif boleh menghadapi masalah apabila ia mengembalikan Tiada tanpa diduga. Mari kita teroka contoh khusus untuk memahami punca dan penyelesaian.

Pertimbangkan coretan kod berikut:

<code class="python">def gcdIter(a, b):
    a, b = min(a, b), max(a, b)  # Assign smaller value to 'a' and larger value to 'b'

    if b % a == 0:
        print(a)
        return a
    gcdIter(a, b % a)</code>
Salin selepas log masuk

Kod ini bertujuan untuk mengira pembahagi sepunya terbesar (GCD) menggunakan pendekatan berulang . Walau bagaimanapun, ia salah mengembalikan Tiada dalam beberapa kes.

Untuk memahami sebabnya, mari kita periksa panggilan rekursif:

<code class="python">gcdIter(a, b % a)</code>
Salin selepas log masuk

Panggilan ini membuat satu lagi panggilan rekursif ke fungsi gcdIter dengan nilai yang dikemas kini dan b. Walau bagaimanapun, nilai pulangan bagi panggilan rekursif ini diabaikan, yang mengakibatkan Tiada dikembalikan oleh fungsi gcdIter asal.

Penyelesaian adalah untuk mengembalikan hasil panggilan rekursif. Versi fungsi yang betul kelihatan seperti ini:

<code class="python">def gcdIter(a, b):
    a, b = min(a, b), max(a, b)  # Assign smaller value to 'a' and larger value to 'b'

    if b % a == 0:
        return a
    return gcdIter(a, b % a)</code>
Salin selepas log masuk

Atas ialah kandungan terperinci Mengapa Fungsi Rekursif Python Saya Tidak Kembali?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan