Methoden Java ist auch eine Insel Listing 2.40 Recursion

ChrisBT

Mitglied
Hallo zusammen,

ich habe angefangen Java zu lernen und bin auf ein Problemchen gestoßen, welches mich nun schon geraume Zeit beschäftigt.
Ich verstehe einfach nicht, warum die Methode down2 die Zahlen aufsteigend ausgibt.
Wie kommt es dazu?
Java:
static void down2( int n ){
    if ( n <= 0 )
        return;
    
    down2( n - 1 );
    System.out.print( n + ", ");
}
Aufgerufen wird die Methode aus der main-Methode mit down2(10);
Ich habe die Erklärung im Buch bestimmt schon 20 Mal gelesen. Ich verstehe einfach nicht, warum, nachdem n=0 ist, System.out.print eine 1 ausgibt und warum down2(int) im Anschluss mit 2 belegt ist.

Vielleicht kann mir das einer mal mit einfachen Worten erklären, wie der Ablauf und die Belegung der Variablen ist.

Viele Grüße
Chris
 
G

Gelöschtes Mitglied 62473

Gast
Man kann sich das mit einem Trick leichter visualisieren:
Java:
	static void down2(int n, int i) {
		if (n <= 0)
			return;
		System.out.printf("%" + i + "s%s%n", "", n);
		down2(n - 1, i + 1);
		System.out.printf("%" + i + "s%s%n", "", n);
	}

	public static void main(String[] args) {
		down2(5, 1);
	}

Code:
 5
  4
   3
    2
     1
     1
    2
   3
  4
 5

Wie man hier sieht wird n erst heruntergezählt und danach dann ausgegeben.
 

ChrisBT

Mitglied
Hallo Flown und Xyz1,
vielen Dank fuer die schnellen Antworten.
Wie die runterzaehlende Rekursion ablaeuft, zumindest die in dem Buch, habe ich verstanden, auch dass die andere (down2) hochzaehlt, habe ich gesehen.
Meine Frage war ja, warum macht sie das. Warum hat "n" bei Abbruch durch die if-Ueberpruefung (n<=0) den Wert 1 bei der Ausgabe durch System.out? Der sollte doch "0" sein.
Ist die "1" ausgegeben, wird down2 ploetzlich mit down2(2) aufgerufen. Warum ist das so?
Hier haenge ich fest und verbeisse mich darin und komme dadurch nicht weiter.

Sorry fuer dieses ue, oe usw.. Sitze gerade in den USA und habe nur eine englische Tastatur.
 

CSHW89

Bekanntes Mitglied
Ist die "1" ausgegeben, wird down2 ploetzlich mit down2(2) aufgerufen. Warum ist das so?
Nein down2(2) wird nicht nochmal aufgerufen, sondern der vorherige Aufruf wird fortgesetzt. Um es mal etwas klarer zu erklären:

Code:
main: Ruft down2(5) auf und wartet bis diese abgearbeitet ist
  down2(5): Ruft down2(4) auf und wartet bis diese abgearbeitet ist
    down2(4): Ruft down2(3) auf und wartet bis diese abgearbeitet ist
      down2(3): Ruft down2(2) auf und wartet bis diese abgearbeitet ist
        down2(2): Ruft down2(1) auf und wartet bis diese abgearbeitet ist
          down2(1): Ruft down2(0) auf und wartet bis diese abgearbeitet ist
            down2(0): Macht nichts
          down2(1): Wird nach Aufruf down2(0) fortgesetzt und gibt "1, " aus
        down2(2): Wird nach Aufruf down2(1) fortgesetzt und gibt "2, " aus
      down2(3): Wird nach Aufruf down2(2) fortgesetzt und gibt "3, " aus
    down2(4): Wird nach Aufruf down2(3) fortgesetzt und gibt "4, " aus
  down2(5): Wird nach Aufruf down2(4) fortgesetzt und gibt "5, " aus
 

ChrisBT

Mitglied
Danke fuer deine Erklaerung, CSHW89.
Ich versuche mal was, um zu erklaeren, was fuer mich so undurchsichtig ist.
Hier die Methode mit den Werten der Variablen, so wie ich das verstehe:
down2(3) aufrufen...
Code:
static void down2( 3 ){
    if ( 3 <= 0 )
        return;
    
    down2( 3 - 1 ); // Ruft down2(2) auf
    System.out.print( 3 + ", "); // Noch keine Ausgabe
}
Code:
static void down2( 2 ){
    if ( 2 <= 0 )
        return;
    
    down2( 2 - 1 );//Ruft down2(1) auf
    System.out.print( 2 + ", ");//Noch keine Ausgabe
}
Code:
static void down2( 1 ){
    if ( 1 <= 0 )
        return;
    
    down2( 1 - 1 );//Ruft down2(0) auf
    System.out.print( 1 + ", ");//Noch keine Ausgabe
}
Code:
static void down2( 0 ){
    if ( 0 <= 0 )
        return; // Springt zu System.out
    
    down2( 0 - 1 );//Ruft down2(-1) auf ???? Da hakt es bei mir!
    System.out.print( 0 + ", ");// Ist doch 0 oder nicht?
}

Es ist sicher ganz einfach, aber ich stehe echt im Moment auf dem Schlauch. :rolleyes:
 

CSHW89

Bekanntes Mitglied
Danke fuer deine Erklaerung, CSHW89.
Ich versuche mal was, um zu erklaeren, was fuer mich so undurchsichtig ist.
Hier die Methode mit den Werten der Variablen, so wie ich das verstehe:
down2(3) aufrufen...
Code:
static void down2( 3 ){
    if ( 3 <= 0 )   // (1)
        return;
  
    down2( 3 - 1 );   // (2)
    System.out.print( 3 + ", ");   // (11)
}
Code:
static void down2( 2 ){
    if ( 2 <= 0 )   // (3)
        return;
  
    down2( 2 - 1 );   // (4)
    System.out.print( 2 + ", ");   // (10)
}
Code:
static void down2( 1 ){
    if ( 1 <= 0 )   // (5)
        return;
  
    down2( 1 - 1 );   // (6)
    System.out.print( 1 + ", ");   // (9)
}
Code:
static void down2( 0 ){
    if ( 0 <= 0 )   // (7)
        return;   // (8)
  
    down2( 0 - 1 );   // Wegen (8) wird dies hier nicht mehr ausgeführt. "return" beendet diesen Aufruf.
    System.out.print( 0 + ", ");
}

Es ist sicher ganz einfach, aber ich stehe echt im Moment auf dem Schlauch. :rolleyes:

Vielleicht mal ein weiteren Versuch. Ich habe in deinem Kommentar die Ausführungsreihenfolge markiert.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
berserkerdq2 Findet eine parallele Verarbeitung in Java bei Threads erst statt, wenn man die Methoden auch synchronized? Und wie sieht bei Conditions aus? Java Basics - Anfänger-Themen 8
JordenJost Java ist auch eine Insel für Anfänger Java Basics - Anfänger-Themen 2
F Erste Schritte Java ist auch eine Insel kaufen? Java Basics - Anfänger-Themen 2
D Türme von Hanoi in "Java ist auch eine Insel" Java Basics - Anfänger-Themen 4
DaniSahne96 Frage zu Java ist auch eine Insel Java Basics - Anfänger-Themen 12
J Geldberechner(aus Java ist auch eine Insel) Java Basics - Anfänger-Themen 6
G Erste Schritte JAVA ist auch eine Insel Java Basics - Anfänger-Themen 7
T Frage aus dem Buch JAVA ist auch eine Insel Java Basics - Anfänger-Themen 11
S Codebeispiel aus Java ist auch eine Insel. Java Basics - Anfänger-Themen 2
T Java ist auch eine Insel: Beispielprogramm fehlerhaft? Java Basics - Anfänger-Themen 2
G Kann Java-Programm nicht als jar aufrufen, auch als EXE nicht Java Basics - Anfänger-Themen 19
berserkerdq2 sqllite in Java, wenn ich mache select count(*) ..., erhalte ich dann nur die gezählte Anzahl oder werden auch die Tabellen ausgegeben? Java Basics - Anfänger-Themen 2
J Projektideen für Java (auch gehobeneres Niveau)? Java Basics - Anfänger-Themen 16
P Kann ich Java - Programme auch ohne Editor öffnen? Java Basics - Anfänger-Themen 70
D Java doppelte Zahlen auch über 10 in einem String entfernen Java Basics - Anfänger-Themen 2
S Java Counter: nur 1 mal hochzählen auch wenn Abfrage mehrmals zutrifft. Java Basics - Anfänger-Themen 1
Hindi93 Java is auch ne Insel CD Java Basics - Anfänger-Themen 8
D BETAVERT aus Excel auch in Java? Java Basics - Anfänger-Themen 4
C seo-Webseiten auch mit Java möglich? Java Basics - Anfänger-Themen 8
L Wie kann ich auch in einem ActionListener ein neues java Pro Java Basics - Anfänger-Themen 8
D flash object mit JS definieren.auch für Java Applet? Java Basics - Anfänger-Themen 13
J Gibts soetwas wie DBTable in Delphi auch in Java Java Basics - Anfänger-Themen 2
H .java Dateien in Eclipse einbinden und ausführen Java Basics - Anfänger-Themen 1
onlyxlia Schlüsselworte Was meint man mit "einen Typ" in Java erstellen? Java Basics - Anfänger-Themen 2
O Java Kara geschweifte Klammern Java Basics - Anfänger-Themen 2
richis-fragen Mausrad logitech kann links und rechts klick wie in java abragen. Java Basics - Anfänger-Themen 15
XWing Java Klssenproblem Java Basics - Anfänger-Themen 4
R Umgebungsvariable java -cp gibt immer Java-Hilfe... Java Basics - Anfänger-Themen 3
farbenlos Csv Datei in Java einlesen Java Basics - Anfänger-Themen 18
F TableModelListener: java.lang.ArrayIndexOutOfBoundsException: 132 Java Basics - Anfänger-Themen 3
G Java 8 - Support-Ende Java Basics - Anfänger-Themen 7
T Java Weihnachtsbaum + Rahmen Java Basics - Anfänger-Themen 1
N Will mit Java anfangen Java Basics - Anfänger-Themen 13
Ü Java Array - Buchstaben als Zahlen ausgeben Java Basics - Anfänger-Themen 22
M Java Iterator Verständnisfrage Java Basics - Anfänger-Themen 6
M Java Mail Programm Java Basics - Anfänger-Themen 4
Sniper1000 Java 391 für Windows Java Basics - Anfänger-Themen 37
J Java long- in int-Variable umwandeln Java Basics - Anfänger-Themen 6
JaZuDemNo Java im Studium Java Basics - Anfänger-Themen 7
E Java Programm zur anzeige, ob Winter- oder Sommerzeit herrscht Java Basics - Anfänger-Themen 62
I QR code in Java selber generieren Java Basics - Anfänger-Themen 5
V Java-Ausnahmebehandlung: Behandlung geprüfter Ausnahmen Java Basics - Anfänger-Themen 1
krgewb Java Streams Java Basics - Anfänger-Themen 10
A Überwältigt von der komplexen Java Welt Java Basics - Anfänger-Themen 29
O Mehrfachvererbung auf Spezifikations- und Implementierungsebene in Java. Interfaces Java Basics - Anfänger-Themen 19
John_Sace Homogene Realisierung von Generics in Java ? Java Basics - Anfänger-Themen 19
P Meldung aus Java-Klasse in Thread an aufrufende Klasse Java Basics - Anfänger-Themen 1
R mit Java API arbeiten Java Basics - Anfänger-Themen 9
P JDK installieren Probleme bei der Java-Installation Java Basics - Anfänger-Themen 8
S Java: Wie sortiere ich eine ArrayList benutzerdefinierter Objekte nach einem bestimmten Attribut? Java Basics - Anfänger-Themen 2
Timo12345 JNLP File mit Java öffnen Java Basics - Anfänger-Themen 2
S Video Editierung mit Java.._ Java Basics - Anfänger-Themen 2
F Einstelungen in Java - CursorBlinkRate Java Basics - Anfänger-Themen 10
A PHP $_POST["name"] in Java Java Basics - Anfänger-Themen 3
vivansai21 Is there a oneliner to create a SortedSet filled with one or multiple elements in Java? Java Basics - Anfänger-Themen 9
Athro-Hiro Weißes Bild in Java erstellen Java Basics - Anfänger-Themen 3
Arjunreddy Can someone please tell me how to use a debugger in BlueJ(a Java environment) Java Basics - Anfänger-Themen 1
M Java assoziationen (UML) Java Basics - Anfänger-Themen 8
H Excel-Tabellen mit Java erstellen Java Basics - Anfänger-Themen 4
Simon16 Java ArrayListe von einer Klasse sortieren Java Basics - Anfänger-Themen 2
P Wie kann ich in meinem Java Programm etwas dauerhaft speichern? Java Basics - Anfänger-Themen 5
H Nutzt Eclipse alle CPU-Threads beim Ausführen von Java-Programmen? Java Basics - Anfänger-Themen 4
xXGrowGuruXx Java einstieg, leichte sache 0 verstanden Java Basics - Anfänger-Themen 7
A java.sql.SQLException: Data type mismatch. Java Basics - Anfänger-Themen 1
H Java-Programm zur Ausgabe von Zuständen Java Basics - Anfänger-Themen 80
N Java Spiel Figur auf dem Hintergrundbild bewegen. Java Basics - Anfänger-Themen 11
N Java Taschenrechner hat Jemand vlt einen Tipp dafür wie ich jetzt die buttons verbinden kann und das Ergebnis auf dem textfield anzeigen lassen kann Java Basics - Anfänger-Themen 13
A Lerngruppe Java Java Basics - Anfänger-Themen 2
G Help me in the Java Program Java Basics - Anfänger-Themen 2
L Java- Vererbung Java Basics - Anfänger-Themen 4
LimDul Suche Java Stream Tutorial Java Basics - Anfänger-Themen 2
_so_far_away_ Ich möchte Java lernen Java Basics - Anfänger-Themen 11
benny1993 Java Programm erstellen für ein Fußball-Turnier Java Basics - Anfänger-Themen 3
M Datentypen While-Schleife eine Java Methode erstellen Java Basics - Anfänger-Themen 3
V Bild per Java Script austauschen Java Basics - Anfänger-Themen 7
MoxMorris this Keyword in Java Java Basics - Anfänger-Themen 14
D Wie kann man in Java nach Arrays auf Duplikate prüfen Java Basics - Anfänger-Themen 12
wolei JAVA Zeitdifferenz feststellen. Java Basics - Anfänger-Themen 4
DiyarcanZeren Rekursion in Java Java Basics - Anfänger-Themen 5
wolei Java generic interface in a generic class Java Basics - Anfänger-Themen 6
monsterherz Ablauf der Erstellung eines Java Programmes Java Basics - Anfänger-Themen 17
monsterherz Circle.java:5: error: <identifier> expected Java Basics - Anfänger-Themen 2
julian-fr Wie kann ich am besten Java lernen? Java Basics - Anfänger-Themen 17
A Java-Properties und -RessourceBundles Java Basics - Anfänger-Themen 5
lrnz22 Java-Basics-Aufgabe Java Basics - Anfänger-Themen 8
R Java kann nicht installiert werden Java Basics - Anfänger-Themen 8
marcelnedza Finde meinen Fehler in einer Methode nicht, Java Karol Java Basics - Anfänger-Themen 15
G In ein java Dokument Ton einbinden Java Basics - Anfänger-Themen 1
C was heisst es wenn java ']' erwartet ? Java Basics - Anfänger-Themen 2
KeinJavaFreak Erste Schritte Programm "Java(TM) Platform SE binary " nicht vorhanden Java Basics - Anfänger-Themen 1
KeinJavaFreak Erste Schritte Java "Executable Jar File" nicht vorhanden Java Basics - Anfänger-Themen 1
melisax Java 2D-Array Tabelle Java Basics - Anfänger-Themen 4
melisax Java Array Wert an bestimmtem Index angeben Java Basics - Anfänger-Themen 14
J Java Testklasse Java Basics - Anfänger-Themen 5
P Java Selenium . Parameterized.Parameters erzeugt eine Fehlermeldung Java Basics - Anfänger-Themen 14
W Java-Code mit Array Java Basics - Anfänger-Themen 14
W Java-Code Java Basics - Anfänger-Themen 2
P BeforeEach AfterEach werden nicht ausgeführt. Java / Selenium Java Basics - Anfänger-Themen 4
A Wie führe ich eine Batch-Datei von meiner Java-Anwendung aus? Java Basics - Anfänger-Themen 18
W Java code- TicTac toe Java Basics - Anfänger-Themen 51

Ähnliche Java Themen

Neue Themen


Oben