<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="de">
	<id>https://wiki-de.moshellshocker.dns64.de/index.php?action=history&amp;feed=atom&amp;title=Rekursive_Programmierung</id>
	<title>Rekursive Programmierung - Versionsgeschichte</title>
	<link rel="self" type="application/atom+xml" href="https://wiki-de.moshellshocker.dns64.de/index.php?action=history&amp;feed=atom&amp;title=Rekursive_Programmierung"/>
	<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Rekursive_Programmierung&amp;action=history"/>
	<updated>2026-05-19T11:40:49Z</updated>
	<subtitle>Versionsgeschichte dieser Seite in Wikipedia (Deutsch) – Lokale Kopie</subtitle>
	<generator>MediaWiki 1.43.8</generator>
	<entry>
		<id>https://wiki-de.moshellshocker.dns64.de/index.php?title=Rekursive_Programmierung&amp;diff=30524&amp;oldid=prev</id>
		<title>imported&gt;Innobello: Änderungen von 93.225.125.39 (Diskussion) auf die letzte Version von Aka zurückgesetzt</title>
		<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Rekursive_Programmierung&amp;diff=30524&amp;oldid=prev"/>
		<updated>2024-12-03T12:27:28Z</updated>

		<summary type="html">&lt;p&gt;Änderungen von &lt;a href=&quot;/index.php/Spezial:Beitr%C3%A4ge/93.225.125.39&quot; title=&quot;Spezial:Beiträge/93.225.125.39&quot;&gt;93.225.125.39&lt;/a&gt; (&lt;a href=&quot;/index.php?title=Benutzer_Diskussion:93.225.125.39&amp;amp;action=edit&amp;amp;redlink=1&quot; class=&quot;new&quot; title=&quot;Benutzer Diskussion:93.225.125.39 (Seite nicht vorhanden)&quot;&gt;Diskussion&lt;/a&gt;) auf die letzte Version von &lt;a href=&quot;/index.php?title=Benutzer:Aka&amp;amp;action=edit&amp;amp;redlink=1&quot; class=&quot;new&quot; title=&quot;Benutzer:Aka (Seite nicht vorhanden)&quot;&gt;Aka&lt;/a&gt; zurückgesetzt&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Neue Seite&lt;/b&gt;&lt;/p&gt;&lt;div&gt;Bei der &amp;#039;&amp;#039;&amp;#039;rekursiven Programmierung&amp;#039;&amp;#039;&amp;#039;  ruft sich eine [[Prozedur (Programmierung)|Prozedur]], [[Funktion (Informatik)|Funktion]] oder [[Unterprogramm#Terminologie|Methode]] in einem [[Computerprogramm]] selbst wieder auf (d.&amp;amp;nbsp;h. enthält eine [[Rekursion]]). Auch der gegenseitige Aufruf stellt eine Rekursion dar.&lt;br /&gt;
&lt;br /&gt;
Wichtig bei der [[Rekursion|rekursiven]] [[Programmierung]] ist eine [[Abbruchbedingung]] in dieser [[Funktion (Programmierung)|Funktion]], weil sich das rekursive [[Computerprogramm|Programm]] sonst theoretisch unendlich oft selbst aufrufen würde.&lt;br /&gt;
&lt;br /&gt;
Rekursive [[Programmierung]] kann unter anderem in [[Prozedurale Programmierung|prozeduralen]] und [[Objektorientierte Programmierung|objektorientierten]] [[Programmiersprache]]n angewandt werden. Obwohl diese Sprachen in ihrem Sprachstandard die [[Rekursion]] ausdrücklich zulassen, stellen Selbstaufrufe und gegenseitige Aufrufe hier (aufgrund der verwendeten [[Programmierparadigma|Programmierparadigmen]]) jedoch eher die Ausnahme dar. Auch wenn in der Praxis zur Verbesserung des [[Programmierstil]]s auch hier durchaus häufig auf Rekursion zurückgegriffen wird, sind die meisten [[Funktion (Programmierung)|Funktionen]] in diesen Sprachen doch rein [[Iterative Programmierung|iterativ]].&lt;br /&gt;
&lt;br /&gt;
In einigen Sprachen, wie z. B. in manchen [[funktionale Programmiersprache|funktionalen Programmiersprachen]] oder [[Makroprozessor]]en, muss die rekursive Programmiermethode zwingend verwendet werden, da [[Iterative Programmierung|iterative]] Sprachkonstrukte fehlen.&lt;br /&gt;
&lt;br /&gt;
== Beispiele ==&lt;br /&gt;
&lt;br /&gt;
=== Fakultät ===&lt;br /&gt;
Ein Beispiel für die Verwendung einer [[Rekursion|rekursiven]] [[Programmierung]] ist die Berechnung der [[Fakultät (Mathematik)|Fakultät]] einer Zahl. Die Fakultät ist das [[Produkt (Mathematik)|Produkt]] aller ganzen Zahlen von 1 bis zu dieser Zahl. Die Fakultät von 4 ist also &amp;lt;math&amp;gt;1 \cdot 2 \cdot 3 \cdot 4 = 24&amp;lt;/math&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
Mathematiker definieren die Fakultät meistens so (eine rekursive Definition):&lt;br /&gt;
&lt;br /&gt;
* Die Fakultät der Zahl 0 ist definitionsgemäß 1.&lt;br /&gt;
* Die Fakultät einer ganzen Zahl, die größer als Null ist, ist das Produkt dieser Zahl mit der Fakultät der nächstkleineren ganzen Zahl.&lt;br /&gt;
&lt;br /&gt;
Die Definition funktioniert so:&lt;br /&gt;
&lt;br /&gt;
:* Will man die &amp;#039;&amp;#039;&amp;#039;Fakultät von 4&amp;#039;&amp;#039;&amp;#039; berechnen, so muss man zunächst die Fakultät von 3 berechnen und das Ergebnis mit 4 multiplizieren.&lt;br /&gt;
::* Will man die Fakultät von 3 berechnen, so muss man zunächst die Fakultät von 2 berechnen und das Ergebnis mit 3 multiplizieren.&lt;br /&gt;
:::* Will man die Fakultät von 2 berechnen, so muss man zunächst die Fakultät von 1 berechnen und das Ergebnis mit 2 multiplizieren.&lt;br /&gt;
::::* Will man die Fakultät von 1 berechnen, so muss man zunächst die Fakultät von 0 berechnen und das Ergebnis mit 1 multiplizieren.&lt;br /&gt;
:::::* Die Fakultät von 0 ist nach Definition 1.&lt;br /&gt;
::::* Die Fakultät von 1 ist also 1*1=1&lt;br /&gt;
:::* Die Fakultät von 2 ist also 1*1*2=2&lt;br /&gt;
::* Die Fakultät von 3 ist also 1*1*2*3=6&lt;br /&gt;
:* Die Fakultät von 4 ist also 1*1*2*3*4=24&lt;br /&gt;
&lt;br /&gt;
In einer [[Programmiersprache]] wie Pascal, die rekursive Programmierung zulässt, kann man die [[Fakultät (Mathematik)|Fakultät]] folgendermaßen eingeben:&lt;br /&gt;
&lt;br /&gt;
Man definiert eine [[Funktion (Programmierung)|Funktion]] &amp;#039;&amp;#039;factorial&amp;#039;&amp;#039;, die eine Zahl &amp;#039;&amp;#039;x&amp;#039;&amp;#039; als Eingabewert bekommt. Diese Funktion multipliziert &amp;#039;&amp;#039;x&amp;#039;&amp;#039; mit dem Rückgabewert von &amp;#039;&amp;#039;factorial(x - 1)&amp;#039;&amp;#039; außer bei &amp;#039;&amp;#039;x = 0&amp;#039;&amp;#039;, dann liefert die Funktion das Ergebnis 1. Dies ist die Abbruchbedingung:&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;Rekursive Implementation der Fakultätsfunktion &amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;pascal&amp;quot;&amp;gt;&lt;br /&gt;
function factorial(x: Integer): Integer;&lt;br /&gt;
begin&lt;br /&gt;
    if x = 0 then&lt;br /&gt;
        factorial := 1&lt;br /&gt;
    else&lt;br /&gt;
        factorial := x * factorial(x - 1);&lt;br /&gt;
end;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Mit der Startzahl &amp;#039;&amp;#039;x = 4&amp;#039;&amp;#039; würde der [[Computer]] rechnen:&lt;br /&gt;
&lt;br /&gt;
 4 * (3 * (2 * (1 * factorial(0))))&lt;br /&gt;
&lt;br /&gt;
heraus kommt dann das richtige Ergebnis, nämlich 24.&lt;br /&gt;
&lt;br /&gt;
=== Binäre Suche ===&lt;br /&gt;
Die [[binäre Suche]] in einem vorsortierten [[Feld (Datentyp)|Array]] lässt sich [[Rekursion|rekursiv]] [[Implementierung|implementieren]]. Wenn das mittlere Element kleiner als das gesuchte Element ist, wird die hintere Hälfte des Arrays rekursiv durchsucht. Wenn es größer als das gesuchte Element ist, wird die vordere Hälfte des Arrays rekursiv durchsucht. Ist es gleich dem gesuchten Element, ist die Suche beendet.&lt;br /&gt;
&lt;br /&gt;
Die Abbruchbedingung für die [[Rekursion]] ist erfüllt, wenn das mittlere Element gleich dem gesuchten Element ist, die Suche also erfolgreich ist, oder wenn der Endindex kleiner als der Startindex ist, die Suche also erfolglos ist.&lt;br /&gt;
&lt;br /&gt;
Die folgende [[Funktion (Programmierung)|Funktion]] ([[Methode (Programmierung)|Methode]]) für die [[Rekursion|rekursive]] [[binäre Suche]] ist in der [[Programmiersprache]] [[C-Sharp|C#]]:&amp;lt;syntaxhighlight lang=&amp;quot;c#&amp;quot;&amp;gt;&lt;br /&gt;
int RekursiveBinaereSuche(int[] werte, int gesuchterWert, int startIndex, int endIndex)&lt;br /&gt;
{&lt;br /&gt;
    if (endIndex &amp;lt; startIndex)&lt;br /&gt;
    {&lt;br /&gt;
        // Wenn Element nicht gefunden, dann null zurückgeben&lt;br /&gt;
        return null;&lt;br /&gt;
    }&lt;br /&gt;
    int mittlererIndex = (startIndex + endIndex) / 2;&lt;br /&gt;
    if (werte[mittlererIndex] == gesuchterWert)&lt;br /&gt;
    {&lt;br /&gt;
        // Wenn Element gefunden, dann Index zurückgeben&lt;br /&gt;
        return mittlererIndex;&lt;br /&gt;
    }&lt;br /&gt;
    else&lt;br /&gt;
    {&lt;br /&gt;
        if (werte[mittlererIndex] &amp;lt; gesuchterWert)&lt;br /&gt;
        {&lt;br /&gt;
            // Rekursiver Aufruf der Funktion für die hintere Hälfte&lt;br /&gt;
            return RekursiveBinaereSuche(werte, gesuchterWert, mittlererIndex + 1, endIndex);&lt;br /&gt;
        }&lt;br /&gt;
        else&lt;br /&gt;
        {&lt;br /&gt;
            // Rekursiver Aufruf der Funktion für die vordere Hälfte&lt;br /&gt;
            return RekursiveBinaereSuche(werte, gesuchterWert, startIndex, mittlererIndex - 1);&lt;br /&gt;
        }&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== Effizienz ==&lt;br /&gt;
&lt;br /&gt;
[[Rekursion|Rekursive]] [[Computerprogramm|Programme]] haben in der Regel keine gute [[Performance (Informatik)|Performance]]. Durch die wiederholten Funktionsaufrufe (Inkarnationen) wird immer wieder derselbe Methodeneintrittscode bearbeitet und bei jeder Inkarnation der [[Prozesskontext|Kontext]] gesichert, was zu zusätzlichem [[Programmcode]] und höherem [[Arbeitsspeicher]]verbrauch führt. Alle rekursiven [[Algorithmus|Algorithmen]] lassen sich jedoch auch durch [[iterative Programmierung]] implementieren und umgekehrt.&lt;br /&gt;
&lt;br /&gt;
=== Fakultät ===&lt;br /&gt;
Man hätte die [[Fakultät (Mathematik)|Fakultät]] auch so [[Implementierung|implementieren]] können:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;pascal&amp;quot;&amp;gt;&lt;br /&gt;
function factorial(x: Integer): Integer;&lt;br /&gt;
    var i, number: Integer;&lt;br /&gt;
begin&lt;br /&gt;
    number := 1;&lt;br /&gt;
&lt;br /&gt;
    for i := 1 to x do&lt;br /&gt;
        number := number * i;&lt;br /&gt;
&lt;br /&gt;
    factorial := number;&lt;br /&gt;
end;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
Hierbei gilt die Regel, dass für einfache Probleme eine [[Iterative Programmierung|iterative]] Implementierung häufig effizienter ist. So sollte z.&amp;amp;nbsp;B. auch die Fakultätsfunktion der Effizienz wegen in der Praxis iterativ implementiert werden. Bei komplizierten Problemstellungen (z.&amp;amp;nbsp;B. Aufgaben mit [[Baum (Graphentheorie)|Bäumen]]) hingegen lohnt sich oftmals der Einsatz einer rekursiven Lösung, da für solche Probleme eine iterative Formulierung schnell sehr unübersichtlich – und ineffizient – werden kann, da im schlimmsten Fall der [[Stapelspeicher|Stack]] durch den iterativen [[Algorithmus]] selbst verwaltet werden muss, was sonst der [[Prozessor]] direkt erledigt.&lt;br /&gt;
&lt;br /&gt;
Nicht alle [[Höhere Programmiersprache|höheren Programmiersprachen]] lassen rekursive Aufrufe zu. Ein Beispiel dazu ist älteres [[Fortran]]. Ab Fortran 90 sind rekursive Aufrufe möglich. Andere [[Programmiersprache]]n sind dagegen grundsätzlich rekursiv (wie z.&amp;amp;nbsp;B. [[Prolog (Programmiersprache)|Prolog]]). Solche rekursiven Programmiersprachen und auch andere Sprachen wie z.&amp;amp;nbsp;B. [[Scheme]] setzen die [[Rekursion]] meistens effizient um.&lt;br /&gt;
&lt;br /&gt;
== Implementierung ==&lt;br /&gt;
[[Rekursion]] wird in der Regel durch einen [[Stapelspeicher|Stack]] implementiert, der die Rücksprungadressen, aber auch alle lokalen Variablen und eventuell Funktionsergebnisse aufnimmt. Würde man, wie im obenstehenden Beispiel, die [[Fakultät (Mathematik)|Fakultät]] von 4 berechnen, so würde jeder Aufruf folgende Informationen auf den Stack legen:&lt;br /&gt;
&lt;br /&gt;
#Platz für Ergebnis&lt;br /&gt;
#Argument &amp;#039;&amp;#039;x&amp;#039;&amp;#039;&lt;br /&gt;
#Rücksprungadresse&lt;br /&gt;
&lt;br /&gt;
Zunächst würde im Hauptprogramm also &amp;#039;&amp;#039;fac(4)&amp;#039;&amp;#039; aufgerufen und damit die folgenden Informationen auf den [[Stapelspeicher|Stack]] gelegt:&lt;br /&gt;
&lt;br /&gt;
{| border=&amp;quot;0&amp;quot; cellpadding=&amp;quot;3&amp;quot; bordercolor=&amp;quot;#000000&amp;quot;&lt;br /&gt;
| &amp;#039;&amp;#039;&amp;#039;Stapelanfang&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
| &amp;lt;math&amp;gt;\rightarrow&amp;lt;/math&amp;gt;&lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 1&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Platz für Ergebnis&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0e0FF&amp;quot; align=&amp;quot;center&amp;quot; | 2&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;&amp;#039;4&amp;#039;&amp;#039;&amp;#039; (Argument)&lt;br /&gt;
|-&lt;br /&gt;
| &amp;#039;&amp;#039;&amp;#039;Stapelzeiger&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
| &amp;lt;math&amp;gt;\rightarrow&amp;lt;/math&amp;gt;&lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 3&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Rücksprungadresse ins Hauptprogramm&amp;#039;&amp;#039;&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Die Fakultätsfunktion prüft jetzt, ob das Argument 0 ist. Da dies nicht der Fall ist, wird &amp;#039;&amp;#039;4*fac(3)&amp;#039;&amp;#039; berechnet. Zunächst muss also &amp;#039;&amp;#039;fac&amp;#039;&amp;#039; mit dem Argument 3 aufgerufen werden:&lt;br /&gt;
&lt;br /&gt;
{| border=&amp;quot;0&amp;quot; cellpadding=&amp;quot;3&amp;quot; bordercolor=&amp;quot;#000000&amp;quot;&lt;br /&gt;
| &amp;#039;&amp;#039;&amp;#039;Stapelanfang&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
| &amp;lt;math&amp;gt;\rightarrow&amp;lt;/math&amp;gt;&lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 1&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Platz für Ergebnis&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0e0FF&amp;quot; align=&amp;quot;center&amp;quot; | 2&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;&amp;#039;4&amp;#039;&amp;#039;&amp;#039; (Argument)&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 3&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Rücksprungadresse ins Hauptprogramm&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 4&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Platz für Ergebnis&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0e0FF&amp;quot; align=&amp;quot;center&amp;quot; | 5&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;&amp;#039;3&amp;#039;&amp;#039;&amp;#039; (Argument)&lt;br /&gt;
|-&lt;br /&gt;
| &amp;#039;&amp;#039;&amp;#039;Stapelzeiger&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
| &amp;lt;math&amp;gt;\rightarrow&amp;lt;/math&amp;gt;&lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 6&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Rücksprungadresse in die Fakultätsfunktion&amp;#039;&amp;#039;&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Das Argument ist wieder ungleich 0, also geht’s weiter mit &amp;#039;&amp;#039;3*fac(2)&amp;#039;&amp;#039;.&lt;br /&gt;
&lt;br /&gt;
{| border=&amp;quot;0&amp;quot; cellpadding=&amp;quot;3&amp;quot; bordercolor=&amp;quot;#000000&amp;quot;&lt;br /&gt;
| &amp;#039;&amp;#039;&amp;#039;Stapelanfang&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
| &amp;lt;math&amp;gt;\rightarrow&amp;lt;/math&amp;gt;&lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 1&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Platz für Ergebnis&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0e0FF&amp;quot; align=&amp;quot;center&amp;quot; | 2&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;&amp;#039;4&amp;#039;&amp;#039;&amp;#039; (Argument)&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 3&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Rücksprungadresse ins Hauptprogramm&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 4&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Platz für Ergebnis&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0e0FF&amp;quot; align=&amp;quot;center&amp;quot; | 5&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;&amp;#039;3&amp;#039;&amp;#039;&amp;#039; (Argument)&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 6&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Rücksprungadresse in die Fakultätsfunktion&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 7&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Platz für Ergebnis&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0e0FF&amp;quot; align=&amp;quot;center&amp;quot; | 8&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;&amp;#039;2&amp;#039;&amp;#039;&amp;#039; (Argument)&lt;br /&gt;
|-&lt;br /&gt;
| &amp;#039;&amp;#039;&amp;#039;Stapelzeiger&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
| &amp;lt;math&amp;gt;\rightarrow&amp;lt;/math&amp;gt;&lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 9&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Rücksprungadresse in die Fakultätsfunktion&amp;#039;&amp;#039;&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Das Argument ist wieder ungleich 0, also&amp;#039;&amp;#039;2*fac(1)&amp;#039;&amp;#039;.&lt;br /&gt;
&lt;br /&gt;
{| border=&amp;quot;0&amp;quot; cellpadding=&amp;quot;3&amp;quot; bordercolor=&amp;quot;#000000&amp;quot;&lt;br /&gt;
| &amp;#039;&amp;#039;&amp;#039;Stapelanfang&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
| &amp;lt;math&amp;gt;\rightarrow&amp;lt;/math&amp;gt;&lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 1&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Platz für Ergebnis&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0e0FF&amp;quot; align=&amp;quot;center&amp;quot; | 2&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;&amp;#039;4&amp;#039;&amp;#039;&amp;#039; (Argument)&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 3&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Rücksprungadresse ins Hauptprogramm&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 4&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Platz für Ergebnis&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0e0FF&amp;quot; align=&amp;quot;center&amp;quot; | 5&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;&amp;#039;3&amp;#039;&amp;#039;&amp;#039; (Argument)&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 6&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Rücksprungadresse in die Fakultätsfunktion&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 7&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Platz für Ergebnis&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0e0FF&amp;quot; align=&amp;quot;center&amp;quot; | 8&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;&amp;#039;2&amp;#039;&amp;#039;&amp;#039; (Argument)&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 9&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Rücksprungadresse in die Fakultätsfunktion&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 10&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Platz für Ergebnis&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0e0FF&amp;quot; align=&amp;quot;center&amp;quot; | 11&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;&amp;#039;1&amp;#039;&amp;#039;&amp;#039; (Argument)&lt;br /&gt;
|-&lt;br /&gt;
| &amp;#039;&amp;#039;&amp;#039;Stapelzeiger&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
| &amp;lt;math&amp;gt;\rightarrow&amp;lt;/math&amp;gt;&lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 12&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Rücksprungadresse in die Fakultätsfunktion&amp;#039;&amp;#039;&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Das Argument ist wieder ungleich 0, also&amp;#039;&amp;#039;1*fac(0)&amp;#039;&amp;#039;.&lt;br /&gt;
&lt;br /&gt;
{| border=&amp;quot;0&amp;quot; cellpadding=&amp;quot;3&amp;quot; bordercolor=&amp;quot;#000000&amp;quot;&lt;br /&gt;
| &amp;#039;&amp;#039;&amp;#039;Stapelanfang&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
| &amp;lt;math&amp;gt;\rightarrow&amp;lt;/math&amp;gt;&lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 1&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Platz für Ergebnis&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0e0FF&amp;quot; align=&amp;quot;center&amp;quot; | 2&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;&amp;#039;4&amp;#039;&amp;#039;&amp;#039; (Argument)&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 3&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Rücksprungadresse ins Hauptprogramm&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 4&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Platz für Ergebnis&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0e0FF&amp;quot; align=&amp;quot;center&amp;quot; | 5&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;&amp;#039;3&amp;#039;&amp;#039;&amp;#039; (Argument)&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 6&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Rücksprungadresse in die Fakultätsfunktion&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 7&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Platz für Ergebnis&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0e0FF&amp;quot; align=&amp;quot;center&amp;quot; | 8&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;&amp;#039;2&amp;#039;&amp;#039;&amp;#039; (Argument)&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 9&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Rücksprungadresse in die Fakultätsfunktion&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 10&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Platz für Ergebnis&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0e0FF&amp;quot; align=&amp;quot;center&amp;quot; | 11&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;&amp;#039;1&amp;#039;&amp;#039;&amp;#039; (Argument)&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 12&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Rücksprungadresse in die Fakultätsfunktion&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 13&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Platz für Ergebnis&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0e0FF&amp;quot; align=&amp;quot;center&amp;quot; | 14&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;&amp;#039;0&amp;#039;&amp;#039;&amp;#039; (Argument)&lt;br /&gt;
|-&lt;br /&gt;
| &amp;#039;&amp;#039;&amp;#039;Stapelzeiger&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
| &amp;lt;math&amp;gt;\rightarrow&amp;lt;/math&amp;gt;&lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 15&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Rücksprungadresse in die Fakultätsfunktion&amp;#039;&amp;#039;&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Jetzt ist das Argument 0, das Ergebnis also 1. Wir holen die Rücksprungadresse und das Argument vom [[Stapelspeicher|Stack]] und schreiben die 1 in den dafür vorgesehenen Platz. Der [[Rücksprung]] führt in die Fakultätsfunktion zurück:&lt;br /&gt;
&lt;br /&gt;
{| border=&amp;quot;0&amp;quot; cellpadding=&amp;quot;3&amp;quot; bordercolor=&amp;quot;#000000&amp;quot;&lt;br /&gt;
| &amp;#039;&amp;#039;&amp;#039;Stapelanfang&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
| &amp;lt;math&amp;gt;\rightarrow&amp;lt;/math&amp;gt;&lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 1&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Platz für Ergebnis&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0e0FF&amp;quot; align=&amp;quot;center&amp;quot; | 2&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;&amp;#039;4&amp;#039;&amp;#039;&amp;#039; (Argument)&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 3&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Rücksprungadresse ins Hauptprogramm&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 4&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Platz für Ergebnis&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0e0FF&amp;quot; align=&amp;quot;center&amp;quot; | 5&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;&amp;#039;3&amp;#039;&amp;#039;&amp;#039; (Argument)&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 6&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Rücksprungadresse in die Fakultätsfunktion&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 7&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Platz für Ergebnis&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0e0FF&amp;quot; align=&amp;quot;center&amp;quot; | 8&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;&amp;#039;2&amp;#039;&amp;#039;&amp;#039; (Argument)&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 9&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Rücksprungadresse in die Fakultätsfunktion&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 10&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Platz für Ergebnis&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0e0FF&amp;quot; align=&amp;quot;center&amp;quot; | 11&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;&amp;#039;1&amp;#039;&amp;#039;&amp;#039; (Argument)&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 12&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Rücksprungadresse in die Fakultätsfunktion&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &amp;#039;&amp;#039;&amp;#039;Stapelzeiger&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
| &amp;lt;math&amp;gt;\rightarrow&amp;lt;/math&amp;gt;&lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 13&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;&amp;#039;1&amp;#039;&amp;#039;&amp;#039; (Ergebnis)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Jetzt kann man das Ergebnis mit dem Argument multiplizieren (1*1). Das neue Ergebnis ist wieder 1.  Die [[Rücksprungadresse]] und das Argument werden vom [[Stapelspeicher|Stack]] geholt und das neue Ergebnis in den dafür vorgesehenen Platz geschrieben. [[Rücksprung]] in die Fakultätsfunktion:&lt;br /&gt;
&lt;br /&gt;
{| border=&amp;quot;0&amp;quot; cellpadding=&amp;quot;3&amp;quot; bordercolor=&amp;quot;#000000&amp;quot;&lt;br /&gt;
| &amp;#039;&amp;#039;&amp;#039;Stapelanfang&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
| &amp;lt;math&amp;gt;\rightarrow&amp;lt;/math&amp;gt;&lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 1&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Platz für Ergebnis&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0e0FF&amp;quot; align=&amp;quot;center&amp;quot; | 2&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;&amp;#039;4&amp;#039;&amp;#039;&amp;#039; (Argument)&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 3&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Rücksprungadresse ins Hauptprogramm&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 4&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Platz für Ergebnis&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0e0FF&amp;quot; align=&amp;quot;center&amp;quot; | 5&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;&amp;#039;3&amp;#039;&amp;#039;&amp;#039; (Argument)&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 6&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Rücksprungadresse in die Fakultätsfunktion&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 7&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Platz für Ergebnis&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0e0FF&amp;quot; align=&amp;quot;center&amp;quot; | 8&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;&amp;#039;2&amp;#039;&amp;#039;&amp;#039; (Argument)&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 9&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Rücksprungadresse in die Fakultätsfunktion&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &amp;#039;&amp;#039;&amp;#039;Stapelzeiger&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
| &amp;lt;math&amp;gt;\rightarrow&amp;lt;/math&amp;gt;&lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 10&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;&amp;#039;1&amp;#039;&amp;#039;&amp;#039; (Ergebnis)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Wiederum wird das Ergebnis mit dem Argument multipliziert (1*2). Zurück in die Fakultätsfunktion:&lt;br /&gt;
&lt;br /&gt;
{| border=&amp;quot;0&amp;quot; cellpadding=&amp;quot;3&amp;quot; bordercolor=&amp;quot;#000000&amp;quot;&lt;br /&gt;
| &amp;#039;&amp;#039;&amp;#039;Stapelanfang&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
| &amp;lt;math&amp;gt;\rightarrow&amp;lt;/math&amp;gt;&lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 1&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Platz für Ergebnis&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0e0FF&amp;quot; align=&amp;quot;center&amp;quot; | 2&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;&amp;#039;4&amp;#039;&amp;#039;&amp;#039; (Argument)&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 3&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Rücksprungadresse ins Hauptprogramm&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
|&lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 4&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Platz für Ergebnis&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0e0FF&amp;quot; align=&amp;quot;center&amp;quot; | 5&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;&amp;#039;3&amp;#039;&amp;#039;&amp;#039; (Argument)&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 6&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Rücksprungadresse in die Fakultätsfunktion&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &amp;#039;&amp;#039;&amp;#039;Stapelzeiger&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
| &amp;lt;math&amp;gt;\rightarrow&amp;lt;/math&amp;gt;&lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 7&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;&amp;#039;2&amp;#039;&amp;#039;&amp;#039; (Ergebnis)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Das Ergebnis wird mit dem Argument multipliziert (2*3). Zurück in die Fakultätsfunktion:&lt;br /&gt;
&lt;br /&gt;
{| border=&amp;quot;0&amp;quot; cellpadding=&amp;quot;3&amp;quot; bordercolor=&amp;quot;#000000&amp;quot;&lt;br /&gt;
| &amp;#039;&amp;#039;&amp;#039;Stapelanfang&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
| &amp;lt;math&amp;gt;\rightarrow&amp;lt;/math&amp;gt;&lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 1&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Platz für Ergebnis&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0e0FF&amp;quot; align=&amp;quot;center&amp;quot; | 2&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;&amp;#039;4&amp;#039;&amp;#039;&amp;#039; (Argument)&lt;br /&gt;
|-&lt;br /&gt;
| &lt;br /&gt;
| &lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 3&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;Rücksprungadresse ins Hauptprogramm&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| &amp;#039;&amp;#039;&amp;#039;Stapelzeiger&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
| &amp;lt;math&amp;gt;\rightarrow&amp;lt;/math&amp;gt;&lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 4&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;&amp;#039;6&amp;#039;&amp;#039;&amp;#039; (Ergebnis)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Das Ergebnis wird mit dem Argument multipliziert (6*4). Zurück ins Hauptprogramm&lt;br /&gt;
&lt;br /&gt;
{| border=&amp;quot;0&amp;quot; cellpadding=&amp;quot;3&amp;quot; bordercolor=&amp;quot;#000000&amp;quot;&lt;br /&gt;
| &amp;#039;&amp;#039;&amp;#039;Stapelanfang&amp;#039;&amp;#039;&amp;#039;&amp;lt;br&amp;gt;&amp;#039;&amp;#039;&amp;#039;Stapelzeiger&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
| &amp;lt;math&amp;gt;\rightarrow&amp;lt;/math&amp;gt;&lt;br /&gt;
| bgcolor=&amp;quot;#C0E0FF&amp;quot; align=&amp;quot;center&amp;quot; | 1&lt;br /&gt;
| bgcolor=&amp;quot;#C0C0FF&amp;quot; align=&amp;quot;center&amp;quot; | &amp;#039;&amp;#039;&amp;#039;24&amp;#039;&amp;#039;&amp;#039; (Ergebnis)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Das Hauptprogramm muss dann nur noch das Ergebnis &amp;#039;&amp;#039;24&amp;#039;&amp;#039; vom [[Stapelspeicher|Stack]] holen.&lt;br /&gt;
&lt;br /&gt;
== Siehe auch ==&lt;br /&gt;
* [[Quicksort]]&lt;br /&gt;
* [[Endrekursion]]&lt;br /&gt;
* [[Programmierparadigma]]&lt;br /&gt;
* [[Entrekursivierung]]&lt;br /&gt;
&lt;br /&gt;
== Weblinks ==&lt;br /&gt;
{{Wikibooks|Rekursive Labyrinthe}}&lt;br /&gt;
&lt;br /&gt;
[[Kategorie:Programmierparadigma]]&lt;br /&gt;
[[Kategorie:Rekursion]]&lt;/div&gt;</summary>
		<author><name>imported&gt;Innobello</name></author>
	</entry>
</feed>