php 递归函数的三种实现方式,php递归函数三种
php 递归函数的三种实现方式,php递归函数三种
递归函数是我们常用到的一类函数,最基本的特点是函数自身调用自身,但必须在调用自身前有条件判断,否则无限无限调用下去。实现递归函数可以采取什么方式呢?本文列出了三种基本方式。理解其原来需要一定的基础知识水品,包括对全局变量,引用,静态变量的理解,也需对他们的作用范围有所理解。递归函数也是解决无限级分类的一个很好地技巧。如果对无限级分类感兴趣,请参照php利用递归函数实现无限级分类。我习惯套用通俗的话解释复杂的道理,您确实不明白请参见手册。
利用引用做参数
先不管引用做不做参数,必须先明白引用到底是什么?引用不过是指两个不同名的变量指向同一块存储地址。本来每个变量有各自的存储地址,赋值删除各行其道。现在可好,两个变量共享一块存储地址。 $a=&$b; 。实际上指的是 $a 不管不顾自己原来的存储地址,非要和 $b 共享一室了。因而任何对存储地址数值的改变都会影响两个值。
函数之间本来也是各行其是,即便是同名函数。递归函数是考虑将引用作为参数,成为一个桥梁,形成两个函数间的数据共享。虽然两个函数见貌似操作的是不同地址,但是实际上操作的是一块儿内存地址。
<span>function</span> test(<span>$a</span>=0,&<span>$result</span>=<span>array</span><span>()){ </span><span>$a</span>++<span>; </span><span>if</span> (<span>$a</span><10<span>) { </span><span>$result</span>[]=<span>$a</span><span>; test(</span><span>$a</span>,<span>$result</span><span>); }<br />echo $a; </span><span>return</span> <span>$result</span><span>; }</span>
上面的例子非常简答,以$a<10作为判断条件,条件成立,则把$a赋给$result[];将$result的引用传入函数,会将每一次递归产生的$a添加到结果数组$result。因而本例生成的$result数组是 Array ( [0] => 1 [1] => 2 [2] => 3 [3] => 4 [4] => 5 [5] => 6 [6] => 7 [7] => 8 [8] => 9 ) 。
本例比较有意思的是echo $a 的值。相信很多人认为是12345678910吧,其实不然,是1098765432。为什么呢?因为函数还没执行echo $a前就进行了下一次的函数递归。真正执行echo $a是当$a<10条件不满足的时候,echo $a,返回$result,对于上一层而言,执行完递归函数,开始执行本层的echo $a,依次类推。
利用全局变量
利用全局变量完成递归函数,请确保你确实理解什么是全局变量。global在函数内申明变量不过是外部变量的同名引用。变量的作用范围仍然在本函数范围内。改变这些变量的值,外部同名变量的值自然也改变了。但一旦用了&,同名变量不再是同名引用。利用全局变量实现递归函数没必要理解到这么深的一层,还保持原有对全局变量的看法就可以顺理成章理解递归函数。
<span>function</span> test(<span>$a</span>=0,<span>$result</span>=<span>array</span><span>()){ </span><span>global</span> <span>$result</span><span>; </span><span>$a</span>++<span>; </span><span>if</span> (<span>$a</span><10<span>) { </span><span>$result</span>[]=<span>$a</span><span>; test(</span><span>$a,$result</span><span>); } </span><span>return</span> <span>$result</span><span>; }</span>
利用静态变量
我们常常在类中见到static,今天我们把它利用到递归函数中。请记住static的作用:仅在第一次调用函数的时候对变量进行初始化,并且保留变量值。
举个栗子:
<span>function</span><span> test(){ </span><span>static</span> <span>$count</span>=0<span>; </span><span>echo</span> <span>$count</span><span>; </span><span>$count</span>++<span>; } test(); test(); test(); test(); test();</span>
请问这一段代码的执行结果是多少?是00000么?必然不是。是01234。首先第一次调用test(),static对 $count 进行初始化,其后每一次执行完都会保留 $count 的值,不再进行初始化,相当于直接忽略了 static $count=0; 这一句。
因而将static应用到递归函数作用可想而知。在将需要作为递归函数间作为“桥梁"的变量利用static进行初始化,每一次递归都会保留"桥梁变量"的值。
<span>function</span> test(<span>$a</span>=0<span>){ </span><span>static</span> <span>$result</span>=<span>array</span><span>(); </span><span>$a</span>++<span>; </span><span>if</span> (<span>$a</span><10<span>) { </span><span>$result</span>[]=<span>$a</span><span>; test(</span><span>$a</span><span>); } </span><span>return</span> <span>$result</span><span>; }</span>
总结
所谓递归函数,重点是如何处理函数调用自身是如何保证所需要的结果得以在函数间合理"传递",当然也有不需要函数之间传值得递归函数,例如:
<span>function</span> test(<span>$a</span>=0<span>){ </span><span>$a</span>++<span>; </span><span>if</span> (<span>$a</span><10<span>) { </span><span>echo</span> <span>$a</span><span>; test(</span><span>$a</span><span>); } }</span>
面对这样的函数,我们就不必大伤脑筋了。顺便说一句,深入理解变量引用相关知识对解决这类问题大有裨益。

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



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.

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.

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.

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.

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.

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? 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

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
