php递归函数return会出现无法正确返回想要值的情况
php递归函数中使用return的时候会碰到无法正确返回想要的值得情况,如果不明白其中的原因,很难找出错误的,就下面的具体例子来说明一下吧:
function test($i){ $i-=4; if($i<3){ return $i; }else{ test($i); } } echo test(30);
这段代码看起来没有问题,如果不运行一下估计你也不会认为他有什么问题,及时运行起来发现有问题你也不一定知道哪里有问题,但其实这个函数的else里面是有问题的。在这段代码里面执行的结果是没有返回值的。
所以虽然满足条件 $i<3 时return $i整个函数还是不会返回值的。因此对上面的PHP递归函数可做如下修改:
function test($i){ $i-=4; if($i<3){ return $i; }else{ return test($i);//增加return,让函数返回值 } } echo test(30);
相关文章
php递归函数怎么用才有效?php递归函数典型例子
php递归函数 PHP中Array相关函数简介
浅析PHP递归函数返回值的使用

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Untuk mengoptimumkan prestasi fungsi rekursif, anda boleh menggunakan teknik berikut: Gunakan rekursif ekor: Buat panggilan rekursif pada penghujung fungsi untuk mengelakkan overhed rekursif. Memoisasi: Simpan hasil pengiraan untuk mengelakkan pengiraan berulang. Kaedah bahagi dan takluk: menguraikan masalah dan menyelesaikan sub-masalah secara rekursif untuk meningkatkan kecekapan.

Python ialah bahasa pengaturcaraan yang sangat berkuasa, dan ramai pengaturcara memilih Python sebagai bahasa pengaturcaraan utama mereka. Walau bagaimanapun, terlalu banyak fungsi bersarang dalam kod boleh menyebabkan atur cara sukar untuk dikekalkan dan difahami. Artikel ini akan meneroka cara menyelesaikan ralat bersarang fungsi yang berlebihan dalam kod Python. Pengenalan ringkas kepada sarang fungsi Sarang fungsi merujuk kepada proses mentakrifkan fungsi lain dalam badan sesuatu fungsi. Fungsi bersarang boleh menjadikan struktur program lebih jelas dan kod lebih mudah dibaca dan diselenggara. Walau bagaimanapun, terlalu banyak fungsi bersarang boleh membawa kepada struktur kod yang terlalu kompleks.

Fungsi rekursif digunakan dalam algoritma carian untuk meneroka struktur data seperti pokok. Carian pertama mendalam menggunakan timbunan untuk meneroka nod, manakala carian pertama keluasan menggunakan baris gilir untuk melintasi lapisan demi lapisan. Dalam aplikasi praktikal, seperti mencari fail, fungsi rekursif boleh digunakan untuk mencari fail tertentu dalam direktori tertentu.

Syarat keluar dari fungsi rekursif C++ termasuk: Syarat garis dasar: Semak sama ada fungsi mencapai keadaan yang boleh mengembalikan hasil secara langsung, biasanya menilai sama ada keadaan atau nilai parameter tertentu memenuhi ambang. Syarat penamatan rekursif: Alternatif kepada atau sebagai tambahan kepada syarat garis dasar, memastikan fungsi berhenti selepas beberapa panggilan rekursif tertentu, dengan menjejak kedalaman rekursif atau menetapkan had kedalaman rekursif maksimum.

Aplikasi fungsi rekursif dalam algoritma pengisihan dalam C++ Algoritma isihan sisipan dan gabungan yang dilaksanakan oleh fungsi rekursif boleh menguraikan masalah kompleks kepada sub-masalah yang lebih kecil dan menyelesaikannya dengan cekap melalui panggilan rekursif. Isih sisipan: Mengisih tatasusunan dengan memasukkan elemen satu demi satu. Cantumkan isihan: Bahagi dan takluk, bahagikan tatasusunan dan susun sub-tatasusunan secara rekursif, dan akhirnya gabungkan sub-tatasusunan yang diisih.

Strategi pengoptimuman rekursif ekor secara berkesan mengurangkan kedalaman tindanan panggilan fungsi dan menghalang limpahan tindanan dengan menukarkan panggilan rekursif ekor kepada gelung. Strategi pengoptimuman termasuk: Kesan rekursif ekor: Semak sama ada terdapat panggilan rekursif ekor dalam fungsi. Tukar fungsi kepada gelung: Gunakan gelung dan bukannya panggilan rekursif ekor dan kekalkan tindanan untuk menyimpan keadaan perantaraan.

Bagaimana untuk melaksanakan faktorial menggunakan fungsi rekursif dalam bahasa Go? Faktorial ialah pengiraan biasa dalam matematik yang mendarabkan integer bukan negatif n dengan semua integer positif yang lebih kecil daripadanya, sehingga 1. Sebagai contoh, faktorial bagi 5 boleh dinyatakan sebagai 5!, dikira sebagai 54321=120. Dalam pengaturcaraan komputer, kita sering menggunakan fungsi rekursif untuk melaksanakan pengiraan faktorial. Pertama, kita perlu memahami konsep fungsi rekursif. Fungsi rekursif merujuk kepada proses memanggil fungsi itu sendiri dalam definisi fungsi. Apabila menyelesaikan masalah, fungsi rekursif akan berterusan

Di sini kami mempunyai direktori. Tugas kami adalah untuk mencipta program C untuk menyenaraikan semua fail dan subdirektori dalam direktori. Direktori ialah tempat/kawasan/lokasi di mana satu set fail akan disimpan. Subdirektori ialah direktori dalam direktori akar, yang, seterusnya, boleh mempunyai subdirektori lain. Dalam bahasa pengaturcaraan C anda boleh menyenaraikan semua fail dan subdirektori dengan mudah dalam direktori. Program berikut menunjukkan cara menyenaraikan semua fail dan subdirektori dalam direktori. //Contoh program C untuk menyenaraikan semua fail dan subdirektori dalam direktori Demonstrasi langsung #include<stdio.h>#include<dirent.h>intmain(void){ &am
