Methoden Frage?!

blinc

Neues Mitglied
Schönen guten abend zsm erstmal! :)

habe eine frage bzw ein problem mit folgender Methode;


Java:
	public static int f(int i) {
		if(i==0)
			return 1;
		else
		return i * f (i/2);
	}public static void main(String[] args){
	System.out.println(f(4));

wenn ich dieses "programm" so compiliere erfolgt bei mir die ausgabe "8".
ich kann nur nich nachvollziehen wieso. Habe etwas mit der Zahl rumgespielt um zu gucken
ob ich dahinter steige ( bei 12 ist das ergbnis z.b. 216), aber irgendwie steh ich total aufm schlauch.
Wäre sehr dankbar wenn mir jmd halbwegs plausibel erklären könnte wie man genau auf dieses ergebnis kommt.

vielen dank schon mal im voraus :>
 

InfectedBytes

Top Contributor
das ganze nennt sich rekursion.
die methode ruft sich eben immer wieder selber auf, bis ein bestimmtes kriterium erfüllt ist, in dem Fall wird eben abgebrochen, wenn i==0 ist. Beim Abbruch gibt f den Wert 1 zurück (Zeile 3). dann wird wieder zurückgesprungen in die Methode, welche f aufgerufen hatte.
Wenn man also f mit dem Wert 4 aufruft geschieht folgendes:
Java:
f(4) -> i=4 -> return i*f(i/2) also: return 4*f(2)
 f(2) -> i=2 -> return 2*f(1)
  f(1) -> i=1 -> return 1*f(0)
   f(0) -> return 1;

zusammengefasst wird also 4*(2*(1*1))=8 gerechnet
 

Saheeda

Top Contributor
Du hast hier eine Rekursion vorliegen, das heißt, dass die Methode sich immer wieder selbst aufruft.

Beim Beispiel 4 wäre das:
1. Durchgang: i = 4
2. Durchgang: i = 2
3. Durchgang: i =1
4. Durchgang: i = 0
--> return wird ausgeführt (du gehst deinen Weg "zurück") und die i-Werte der einzelnen Durchgänge multipliziert: 4*2*1 = 8.

EDIT:
Verdammt, zu langsam :D
 
Zuletzt bearbeitet:

blinc

Neues Mitglied
wow, danke für die schnelle Antwort!! :)

also kann man das ganze ähnlich wie eine Schleife betrachten, wobei hier das if( i == 0) return 1; in etwa gleich kommt mit der abbruchbedingung?
 

coco07

Bekanntes Mitglied
Genau :)
Nur dass Methodenaufrufe gestapelt werden und irgendwann Schluss ist, weil die JVM dann nicht mehr genau sagen kann, von wo sie eigentlich ursprünglich kam.
Die Durchgänge einer Schleife sind unbegrenzt!

grüße coco07!
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
R Frage zu Methoden (Rückgabewert u. ohne.) Java Basics - Anfänger-Themen 2
M konzeptuelle Frage: In welcher Klasse definiert man am Besten Methoden, die die Kommunikation mit dem User regeln? Java Basics - Anfänger-Themen 8
H Frage zu Methoden/Funktionen Java Basics - Anfänger-Themen 3
L Frage zur Aufgabe mit Methoden Java Basics - Anfänger-Themen 6
L Frage zur Rückgabe von Werten bei Methoden Java Basics - Anfänger-Themen 4
Y Frage zur überschriebene Methoden Java Basics - Anfänger-Themen 5
J Grundsätzliche Frage zu return Types in Methoden Java Basics - Anfänger-Themen 6
O Frage zum Aufruf überladener Methoden Java Basics - Anfänger-Themen 4
O Frage zu Methoden Java Basics - Anfänger-Themen 7
S OOP Frage: Methoden nur bei bestimmten Gegebenheiten aufrufbar machen? Java Basics - Anfänger-Themen 4
M Frage bzgl. Testbarkeit von Methoden in Relation zu Ihren Abhängigkeiten Java Basics - Anfänger-Themen 11
H Vererbung theoretische Frage zur Vererbung/Methoden Java Basics - Anfänger-Themen 7
E Einfache Frage zur Parameterübergabe in Methoden Java Basics - Anfänger-Themen 8
J Verständniss Frage zu Klassen, Objekte und Methoden Java Basics - Anfänger-Themen 8
J Kleine Frage zu Methoden & OOP Java Basics - Anfänger-Themen 4
M Frage zur Erstellung von Methoden Java Basics - Anfänger-Themen 4
G Frage zur Vererbung und überschreiben von Methoden Java Basics - Anfänger-Themen 6
D Blöde(?) Frage zu Konstruktoren und set-Methoden Java Basics - Anfänger-Themen 3
R eine frage wegen methoden und if statments Java Basics - Anfänger-Themen 6
K Simple Frage zu Methoden und Rückgabewerte Java Basics - Anfänger-Themen 3
A Frage zu Methoden Java Basics - Anfänger-Themen 7
G dringende frage zu klassen und methoden ( klassendiagramm) Java Basics - Anfänger-Themen 19
D Frage zu Methoden Java Basics - Anfänger-Themen 6
R Frage zu Thread und aufruf von Methoden Java Basics - Anfänger-Themen 2
R Frage zu synchronisierten Methoden Java Basics - Anfänger-Themen 2
emreiu Methoden Rekursive Methoden Runter- & Hochzählen Java Basics - Anfänger-Themen 2
U Funktionale Interfaces mit mehreren abstrakten Methoden? Java Basics - Anfänger-Themen 8
MoxMorris Einige Methoden aus verschiedenen Klassen nacheinander auszuführen läuft seltsam Java Basics - Anfänger-Themen 2
J Argumente in Methoden übergeben Java Basics - Anfänger-Themen 1
XWing Methoden rückgabe Problem? Java Basics - Anfänger-Themen 6
Say Class scope und Instance scope und Getter nur selbstgeschrieben Methoden Java Basics - Anfänger-Themen 11
I Gleiche Klassen und Methoden in unterschiedlichen Projekten nutzen Java Basics - Anfänger-Themen 2
N Klassen Methoden anderer Klassen aufrufen Java Basics - Anfänger-Themen 4
Renjiroo Java Bmi Rechner mit Methoden Java Basics - Anfänger-Themen 4
frager2345 Thread - Methoden synchronized deklarieren Java Basics - Anfänger-Themen 10
M Designentscheidung von Attributen/Methoden im Falle von Vererbung Java Basics - Anfänger-Themen 8
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
Alen123 Erstes Arbeiten mit Methoden. Java Basics - Anfänger-Themen 5
berserkerdq2 Zwei Klassen Erben von der Klasse A, die eine Klasse kann ich an Methoden übergeben, die als Parameter A haben, die andere nicht? Java Basics - Anfänger-Themen 3
M Andere Methoden in anderen Klassen aufrufen Java Basics - Anfänger-Themen 11
L Methoden in anderen Klassen nutzen Java Basics - Anfänger-Themen 6
D Gerade oder ungerade Zahl mittels Methoden Java Basics - Anfänger-Themen 13
M Erklärung von Ausnahmebehandlung in Methoden Java Basics - Anfänger-Themen 13
S Methoden 2 non-static Methoden, trotzdem Fehler "non static method can not be referenced from a static context" Java Basics - Anfänger-Themen 9
L Rekursive Methoden Java Basics - Anfänger-Themen 14
X Wie erreiche ich, dass ein Robot weitere Attribute hat, die nicht materialisiert sind, sondern nur über get/ set-Methoden simuliert sind? Java Basics - Anfänger-Themen 1
C Problem mit mehreren Methoden + Scanner Java Basics - Anfänger-Themen 5
W Verschiedene Methoden in einer Klasse in der Main aufrufen? Java Basics - Anfänger-Themen 8
W Methoden aufrufen - auch klassenübergreifend? Java Basics - Anfänger-Themen 9
Kotelettklopfer Methoden nicht aufrufbar Java Basics - Anfänger-Themen 34
R Schulaufgabe, Bruache Hilfe mit non-static Methoden Java Basics - Anfänger-Themen 2
S Vererbung Abstrakte Methoden: Wozu das Ganze?! Java Basics - Anfänger-Themen 7
S abstrakte methoden in subclass? Java Basics - Anfänger-Themen 7
S Methoden - Warum int wenn auch void? Java Basics - Anfänger-Themen 3
H Kann man Methoden öfter aufrufen? Java Basics - Anfänger-Themen 2
CptK Interface Functional interface mit mehreren Methoden Java Basics - Anfänger-Themen 6
P Objekt in mehreren Methoden verwenden. Java Basics - Anfänger-Themen 3
M Aufruf von statischen Methoden einer anderen Klasse Java Basics - Anfänger-Themen 15
lougoldi Verkettung von Methoden und Konstruktoren Java Basics - Anfänger-Themen 4
Zeppi OOP Methoden mit einander Verknüpfen Java Basics - Anfänger-Themen 6
A Löschen von Leerzeichen in einem char array ohne methoden Java Basics - Anfänger-Themen 6
A Parametar übergabe zwischen Methoden Java Basics - Anfänger-Themen 26
D Methoden nach einer bestimmten Reihenfolge ausführen. Java Basics - Anfänger-Themen 20
P Wie rufe ich Methoden mit einer Referenz auf eine Klasse||Objekt auf Java Basics - Anfänger-Themen 4
O Attribute die Methoden zählen Java Basics - Anfänger-Themen 5
M Bräuchte Hilfe bei diesen Methoden Java Basics - Anfänger-Themen 4
G Methoden Methoden mit versch. Datentypen Java Basics - Anfänger-Themen 1
T Ich habe eine Variabel die nicht Methoden übergreifend ist. Kann mir jemand Helfen :) Java Basics - Anfänger-Themen 5
Junger_Basileus Celsius -> Fahrenheit / Strukturierung in statischen Methoden Java Basics - Anfänger-Themen 7
J Verschachtelte Methoden Java Basics - Anfänger-Themen 9
H Methoden in anderen Methoden aufrufen Java Basics - Anfänger-Themen 6
Kawastori Hilfe bei Methoden Übung Java Basics - Anfänger-Themen 6
veryck Methoden Rekursive Methoden mit Rückgabeparameter Java Basics - Anfänger-Themen 9
C Methoden können nicht auf Instanzvariable der Klasse zugreifen Java Basics - Anfänger-Themen 3
P Methoden aufrufen - Fehler Java Basics - Anfänger-Themen 20
C eigene Methoden erstellen (Instanzmethoden) Java Basics - Anfänger-Themen 7
P Klasse hat keinen Zugriff auf getter/setter-Methoden eines Objektes Java Basics - Anfänger-Themen 9
B Methoden Methoden haben kein Zugriff auf variablen Java Basics - Anfänger-Themen 4
M Gettter/Setter Methoden Klassenfelder kapselung und zugriff? Java Basics - Anfänger-Themen 1
C Fernseher-Aufgabe (Methoden, Klassen und Objekte) Java Basics - Anfänger-Themen 63
C Taschenrechner (switch) in Taschenrechner mit Methoden umwandeln Java Basics - Anfänger-Themen 115
H Methoden in großen Klassen gruppieren oder auslagern? Java Basics - Anfänger-Themen 10
G Generics Methoden Java Basics - Anfänger-Themen 7
L Test-Methoden schreiben Java Basics - Anfänger-Themen 13
S throws bei Methoden Java Basics - Anfänger-Themen 4
L Best Practice Code Refactoring für Methoden mit fast gleicher Aufbau Java Basics - Anfänger-Themen 6
I Greedy Methode Methoden nutzen Java Basics - Anfänger-Themen 3
C Methoden-Parameter ist Interface Java Basics - Anfänger-Themen 5
A Klassen und methoden Java Basics - Anfänger-Themen 15
S Übergabe von Arrays an Methoden Java Basics - Anfänger-Themen 20
L Methoden Wie Löse ich ext Methoden Aufruf Fehler? Java Basics - Anfänger-Themen 3
A Bankweverwaltung mit Klassen und Methoden Java Basics - Anfänger-Themen 14
B Methoden Ausgeben Aufgabe Java Basics - Anfänger-Themen 15
M Aufsplitten von Methoden in andere Klassen Java Basics - Anfänger-Themen 2
T Methoden Verständnis Java Basics - Anfänger-Themen 14
M Feste Reihenfolge von dem Ablauf von Methoden Java Basics - Anfänger-Themen 7
G Java Abstrakte Methoden Java Basics - Anfänger-Themen 2
N Klassen Warum kann meine Klasse nicht auf Methoden der anderen Klasse zugreifen? Java Basics - Anfänger-Themen 6
Ich lerne Java. Methoden Mehrere Methoden mit Punkt Java Basics - Anfänger-Themen 45
Kirby.exe Methoden Aufrufe Java Basics - Anfänger-Themen 4

Ähnliche Java Themen

Neue Themen


Oben