Registrierung Kalender Mitgliederliste Teammitglieder Suche Häufig gestellte Fragen Zur Startseite

Informatiker Board » Themengebiete » Theoretische Informatik » Logik » Fibonacci - Rekursiv » Antwort erstellen » Hallo Gast [Anmelden|Registrieren]

Antwort erstellen
Benutzername: (du bist nicht eingeloggt!)
Thema:
Nachricht:

HTML ist nicht erlaubt
BBCode ist erlaubt
Smilies sind erlaubt
Bilder sind erlaubt

Smilies: 21 von 33
smileWinkDaumen hoch
verwirrtAugenzwinkerngeschockt
Mit ZungeGottunglücklich
Forum Kloppebösegroßes Grinsen
TanzentraurigProst
TeufelSpamWillkommen
LehrerLOL HammerZunge raus
Hilfe 
aktuellen Tag schließen
alle Tags schließen
fettgedruckter Textkursiver Textunterstrichener Text zentrierter Text Hyperlink einfügenE-Mail-Adresse einfügenBild einfügen Zitat einfügenListe erstellen CODE einfügenPHP CODE farbig hervorheben
Spamschutz:
Text aus Bild eingeben
Spamschutz

Die letzten 4 Beiträge
eulerscheZahl

Rekursion ist ein tolles Werkzeug. Damit kann man Dinge tun, die sonst gar nicht oder nur mit großem Aufwand möglich wären (z.B. Ackermannfunktion).
Tina_92

Wie ich diese Rekursionen hasse, vielen Dank für die Antwort.
eulerscheZahl

Versuche es mal mit Kontrollausgaben:
code:
1:
2:
3:
4:
5:
6:
7:
8:
9:
10:
11:
12:
13:
14:
15:
public static int fibonacci(int n, int depth) 
{
	for(int i = 0; i  < depth; i++) {
		System.out.print("  ");		
	}
	System.out.println(n);
	if (n==0)
		return 0; 
	if (n==1) 
		return 1;
	if (n>1)
		return fibonacci(n-1, depth+1)+fibonacci(n-2, depth+1);
	else return 0; 
	}
}

liefert für fibonacci(5, 0):
code:
1:
2:
3:
4:
5:
6:
7:
8:
9:
10:
11:
12:
13:
14:
15:
16:
5
  4
    3
      2
        1
        0
      1
    2
      1
      0
  3
    2
      1
      0
    1

Alternativ zeilenweises Debuggen.
Tina_92 Fibonacci - Rekursiv

Meine Frage:
Hi zusammen,

kann mir bitte jemand erklären, wie bei meinem Code die Abarbeitung des rekursiven Funktionsaufrufes erfolgt?



Meine Ideen:
Hier mein Code:

code:
1:
2:
3:
4:
5:
6:
7:
8:
9:
10:
11:
12:
13:
14:
15:

public int fibonacci(int n) 
{
  if (n==0)
        return 0; 
  if (n==1) 
        return 1;
  if (n>1)
        return fibonacci(n-1)+fibonacci(n-2);
  else return 0; 
}




Vielen Dank :-)