Heim Backend-Entwicklung PHP-Tutorial php递归函数return会出现无法正确返回想要值的情况

php递归函数return会出现无法正确返回想要值的情况

Mar 15, 2017 pm 03:42 PM
递归函数

php递归函数中使用return的时候会碰到无法正确返回想要的值得情况,如果不明白其中的原因,很难找出错误的,就下面的具体例子来说明一下吧:

function test($i){
    $i-=4;
    if($i<3){
        return $i;
    }else{
        test($i);
    }
}
echo test(30);
Nach dem Login kopieren

这段代码看起来没有问题,如果不运行一下估计你也不会认为他有什么问题,及时运行起来发现有问题你也不一定知道哪里有问题,但其实这个函数的else里面是有问题的。在这段代码里面执行的结果是没有返回值的。

所以虽然满足条件 $i<3 时return $i整个函数还是不会返回值的。因此对上面的PHP递归函数可做如下修改:

function test($i){
    $i-=4;
    if($i<3){
        return $i;
    }else{
        return test($i);//增加return,让函数返回值
    }
}
echo test(30);
Nach dem Login kopieren

相关文章
php递归函数怎么用才有效?php递归函数典型例子
php递归函数 PHP中Array相关函数简介
浅析PHP递归函数返回值的使用

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Welche Optimierungstechniken gibt es für rekursive C++-Funktionen? Welche Optimierungstechniken gibt es für rekursive C++-Funktionen? Apr 17, 2024 pm 12:24 PM

Um die Leistung rekursiver Funktionen zu optimieren, können Sie die folgenden Techniken verwenden: Verwenden Sie die Endrekursion: Platzieren Sie rekursive Aufrufe am Ende der Funktion, um rekursiven Overhead zu vermeiden. Auswendiglernen: Berechnete Ergebnisse speichern, um wiederholte Berechnungen zu vermeiden. Methode „Teile und herrsche“: Zerlegen Sie das Problem und lösen Sie die Teilprobleme rekursiv, um die Effizienz zu verbessern.

Wie kann der übermäßige Verschachtelungsfehler von Funktionen im Python-Code behoben werden? Wie kann der übermäßige Verschachtelungsfehler von Funktionen im Python-Code behoben werden? Jun 25, 2023 pm 12:35 PM

Python ist eine sehr leistungsfähige Programmiersprache und viele Programmierer wählen Python als ihre Hauptprogrammiersprache. Eine zu starke Verschachtelung von Funktionen im Code kann jedoch die Wartung und das Verständnis des Programms erschweren. In diesem Artikel wird untersucht, wie der übermäßige Funktionsverschachtelungsfehler im Python-Code behoben werden kann. Eine kurze Einführung in die Funktionsverschachtelung Unter Funktionsverschachtelung versteht man den Prozess der Definition einer anderen Funktion im Hauptteil einer Funktion. Durch die Verschachtelung von Funktionen kann die Struktur des Programms klarer und der Code leichter lesbar und wartungsfreundlicher werden. Allerdings können zu viele verschachtelte Funktionen zu einer zu komplexen Codestruktur führen.

Anwendung rekursiver C++-Funktionen in Suchalgorithmen? Anwendung rekursiver C++-Funktionen in Suchalgorithmen? Apr 17, 2024 pm 04:30 PM

Rekursive Funktionen werden in Suchalgorithmen verwendet, um baumartige Datenstrukturen zu untersuchen. Die Tiefensuche verwendet einen Stapel, um Knoten zu erkunden, während die Breitensuche eine Warteschlange verwendet, um Schicht für Schicht zu durchlaufen. In praktischen Anwendungen, beispielsweise beim Suchen von Dateien, können rekursive Funktionen verwendet werden, um nach einer bestimmten Datei in einem angegebenen Verzeichnis zu suchen.

Was sind die Beendigungsbedingungen für eine rekursive Funktion in C++? Was sind die Beendigungsbedingungen für eine rekursive Funktion in C++? Apr 17, 2024 am 11:33 AM

Zu den Exit-Bedingungen rekursiver C++-Funktionen gehören: Grundbedingungen: Überprüfen Sie, ob die Funktion einen Zustand erreicht, der direkt Ergebnisse zurückgeben kann, und beurteilt dabei normalerweise, ob eine bestimmte Bedingung oder ein Parameterwert den Schwellenwert erreicht. Rekursionsbeendigungsbedingung: Alternative oder zusätzlich zur Grundbedingung, die sicherstellt, dass die Funktion nach einer bestimmten Anzahl rekursiver Aufrufe stoppt, indem die Rekursionstiefe verfolgt oder ein maximales Rekursionstiefenlimit festgelegt wird.

Anwendung der rekursiven C++-Funktion im Sortieralgorithmus? Anwendung der rekursiven C++-Funktion im Sortieralgorithmus? Apr 17, 2024 am 11:06 AM

Die Anwendung rekursiver Funktionen in Sortieralgorithmen in C++ Die durch rekursive Funktionen implementierten Einfügungssortierungs- und Zusammenführungssortierungsalgorithmen können komplexe Probleme in kleinere Teilprobleme zerlegen und diese durch rekursive Aufrufe effizient lösen. Einfügungssortierung: Sortiert ein Array, indem Elemente einzeln eingefügt werden. Sortierung zusammenführen: Teilen und erobern, das Array aufteilen und die Unterarrays rekursiv sortieren und schließlich die sortierten Unterarrays zusammenführen.

Wie implementiert man die Schwanzrekursionsoptimierungsstrategie rekursiver C++-Funktionen? Wie implementiert man die Schwanzrekursionsoptimierungsstrategie rekursiver C++-Funktionen? Apr 17, 2024 pm 02:42 PM

Die Strategie zur Optimierung der Schwanzrekursion reduziert effektiv die Tiefe des Funktionsaufrufstapels und verhindert einen Stapelüberlauf, indem sie Schwanzrekursionsaufrufe in Schleifen umwandelt. Zu den Optimierungsstrategien gehören: Tail-Rekursion erkennen: Überprüfen Sie, ob Tail-rekursive Aufrufe in der Funktion vorhanden sind. Konvertieren Sie Funktionen in Schleifen: Verwenden Sie Schleifen anstelle von endrekursiven Aufrufen und pflegen Sie einen Stapel, um den Zwischenzustand zu speichern.

Wie implementiert man faktorielle Funktionen mithilfe rekursiver Funktionen in der Go-Sprache? Wie implementiert man faktorielle Funktionen mithilfe rekursiver Funktionen in der Go-Sprache? Jul 31, 2023 pm 08:31 PM

Wie implementiert man faktorielle Funktionen mithilfe rekursiver Funktionen in der Go-Sprache? Fakultät ist eine in der Mathematik übliche Berechnung, bei der eine nicht negative ganze Zahl n mit allen positiven ganzen Zahlen, die kleiner als diese sind, bis zu 1 multipliziert wird. Beispielsweise kann die Fakultät von 5 als 5! ausgedrückt werden, berechnet als 54321=120. In der Computerprogrammierung verwenden wir häufig rekursive Funktionen, um faktorielle Berechnungen durchzuführen. Zunächst müssen wir das Konzept rekursiver Funktionen verstehen. Eine rekursive Funktion bezieht sich auf den Prozess des Aufrufs der Funktion selbst innerhalb der Funktionsdefinition. Bei der Lösung eines Problems wird eine rekursive Funktion kontinuierlich ausgeführt

C-Programm zum Auflisten aller Dateien und Unterverzeichnisse in einem Verzeichnis C-Programm zum Auflisten aller Dateien und Unterverzeichnisse in einem Verzeichnis Aug 25, 2023 pm 10:09 PM

Hier haben wir ein Verzeichnis. Unsere Aufgabe besteht darin, ein C-Programm zu erstellen, um alle Dateien und Unterverzeichnisse in einem Verzeichnis aufzulisten. Ein Verzeichnis ist ein Ort/Bereich/Ort, an dem eine Reihe von Dateien gespeichert werden. Ein Unterverzeichnis ist ein Verzeichnis innerhalb des Stammverzeichnisses, das wiederum ein weiteres Unterverzeichnis haben kann. In der Programmiersprache C können Sie ganz einfach alle Dateien und Unterverzeichnisse in einem Verzeichnis auflisten. Das folgende Programm zeigt, wie alle Dateien und Unterverzeichnisse in einem Verzeichnis aufgelistet werden. //C-Programmbeispiel zum Auflisten aller Dateien und Unterverzeichnisse im Verzeichnis Live-Demonstration #include<stdio.h>#include<dirent.h>intmain(void){ &am

See all articles