Frage zur Rekursion

anno

Mitglied
Hallo Forum,

[Java]
public static int func_p (int n)
{
if (n==0)
return 0;
else
return n-1;
}

public static int func_s(int m, int n)
{
if(n==0)
return m;
else
return func_p(func_s(m,n-1));
}
[/Java]

Unzwar soll ich die Funktionswerte jeweils rekursiv entsprechend der obigen Methoden berechnen.
Für:

func_s(7,2) und func_s(5,4)


Nun hab ich es versucht zu lösen (Bild 0562) und dann habe ich noch eine Lösung vom Kollegen (Bild 0563). Nun weiß ich nicht wie er zum Beispiel in Aufgabe 1 auf die Werte 6 und 5 kommt (Er ist im Urlaub daher kann ich ihn schlecht fragen).
Könntet Ihr mir bitte helfen?
danke
 

Anhänge

  • IMAG0563.jpg
    IMAG0563.jpg
    47 KB · Aufrufe: 47
  • IMAG0562.jpg
    IMAG0562.jpg
    45 KB · Aufrufe: 46

kaoZ

Top Contributor
Um Rekursion zu verstehen , musst du zunächst die Rekursion verstehen :lol:


Das Ergebnis der ersten Aufgabe ist , insofern deine Methoden oben korrekt sind 7, da sich der Wert von m nie verändert, da er lediglich als Eingabeparameter für deine Methode dient, das ganze wird 2 mal ausgeführt, da die Bedingung erfüllt ist wenn n (2) == 0 ist.

Die Zweite Aufgabe ergibt ebenfalls 5 , da auch hier unter Verwendung deiner oben angegebenen Methoden der Wert von m nie verändert oder in die Berechnung mit einbezogen wird.

Sinnig wäre m um eben die Anzahl an benötigten Durchläufen zu dekrementieren.

Zudem ist die Ersten Methode nicht rekursiv, da sie sich nicht selbst aufruft.

Das ist quasi das was du da programmiert hast, insofer der Code nicht aus irgendwelchen Büchern stammt.

Java:
	public static int methode1(int n){
		return n != 0 ? --n : 0;
	}
	
	public static int methode2(int m, int n){
		if(n == 0 ) {
			return m;
		}
		else{
			System.out.println(n);
			return methode2(m,Foo.methode1(n));
		}
	}

m ändert sich hier ebenfalls nie..... ich hab mal ein sysout eingebaut, damit du sehen kannst das sich zwar n verändert aber du m nicht mit in die Rechnung einbeziehst.

Nun meine 'vorsichtige' Frage, hast du nicht eher versucht diese "Funktion" auf eine Methode abzubilden und dabei ist obiger, augenscheinlicher falscher Code bei entstanden, oder liege ich nun völlig daneben und hab was übersehen ?
 
Zuletzt bearbeitet:

anno

Mitglied
Die Aufgabe stammt aus einer Klausur. Mich hat die Lösung vom Kollegen verwirrt. Ich weiß das die 7 sich nie ändert. Es ändert sich immer das n. Ist die lösung vom Kollegen falsch? Ich habe mir gedacht das er davon ausgegangen ist das in der ersten Methode er anstatt n m benutzt hat.
 

kaoZ

Top Contributor
Also wenn du nun nur den Rechenweg aufschreiben sollst, ist dieser relativ einfach nachzuvollziehen, da wie gesagt n die einzige Variable ist die ihren Wert ändert, dennoch hat m immer den gleichen Wert wie schon beim Übergabe an die Methode, sprich

er hat 'vermutlich' einfach nicht gesehen das n, die Abbruchbedingung ist und nicht m, und es somit den Wert von m notiert, und nicht den Wert den er hätte eigentlich notieren müssen (n), meine ich zumindest, anders würde es ja eigentlich auch keinen Sinn machen, da wie gesagt sich m hier ( laut der Methoden) ja nie verändert.

Ansonsten poste die Aufgabe doch mal ins Matheforum , da sind teilweise einige cracks unterwegs :)
 
Zuletzt bearbeitet:

stg

Top Contributor
Da muss ich kaoz widersprechen, die Lösung von deinem Freund ist richtig!

Das Ergebnis von der ersten Aufgabe ist 5, von der zweiten Aufgabe 1. Berechnet und ausgegeben wird die Differenz von m und n, sofern m größer als n ist.

also
Code:
func_s(7,2) = 7-2 = 5
func_s(5,4) = 5-4 = 1
 
Zuletzt bearbeitet:

stg

Top Contributor
Ein bisschen ausführlicher für den ersten Fall.
Code:
Du startest mit:

    func_s(7,2)

Zurückgegeben wird:

    func_p(func_s(7,1))

Nun wird "von innen nach außen", also zunächst der
Ausdruck func_s(7,1) ausgewertet. Daher kommen wir zu

    func_p(func_p(func_s(7,0))

Nun gibt func_s den Wert 7 zurück und wir haben:

    func_p(func_p(7))

Für 7 gibt func_p nun den Wert 6 zurück, also:

    func_p(6)

Und schließlich erhalten wir:

    5
 
Zuletzt bearbeitet:

kaoZ

Top Contributor
bist du von den Aufgaben auf dem Papier ausgegangen oder von dem oben geposteten Code, macht natürlich sinn das man keine Methode erstellt die eigentlich keine funktion hat ^^

Mein Grundgedanke war ja das dort die Differenz rekursiv errechnet werden soll.

show me the light plz, vielleicht hab ichs auch einfach nur übersehen.
 
Zuletzt bearbeitet:

kaoZ

Top Contributor
Jep, hast recht ich hätte es gleich mal richtig aufräumen sollen.............

Java:
public class Foo{
	public static int func_p (int n){
		return n == 0 ? 0 : n-1;
	}
	 
	public static int func_s(int m, int n){
		return n == 0 ? m : func_p(func_s(m, n-1));
	}
	
	public static void main(String[] args){
		System.out.println(Foo.func_s(7,2));
	}
}

Gibt die Differenz aus.

Antworten sind zu

1 = 5

2 = 1

ich hatte hier beim umschreiben übersehen
Java:
public static int methode2(int m, int n){
		if(n == 0 ) {
			return m;
		}
		else{
			System.out.println(n);
			return methode2(m,Foo.methode1(n));

das nicht methode2 sondern methode1 mit Rückgabwert von Methode2 ausgeführt wird.

Mein Fehler :oops:


kleiner Tip @TO :

verwenden braces
Java:
{}
dann kann man das auch gleich vernünftig lesen ;)
 
Zuletzt bearbeitet:
Ähnliche Java Themen
  Titel Forum Antworten Datum
P Frage zu Rekursion und Backtracking Java Basics - Anfänger-Themen 2
S Frage zu Rekursion... Java Basics - Anfänger-Themen 15
S Noch eine Frage zur Rekursion... Java Basics - Anfänger-Themen 11
S Frage zu einer Rekursion Java Basics - Anfänger-Themen 15
B Rekursion Schneeflocke - Kurze Frage zur Methode Java Basics - Anfänger-Themen 11
A Frage zur Abbruchbedingung Rekursion Java Basics - Anfänger-Themen 8
J Frage zur Rekursion Java Basics - Anfänger-Themen 4
Zrebna Frage zu Test-Driven Development (TDD) Java Basics - Anfänger-Themen 3
I Frage Thymeleaf -> Fehler ignorieren und mit "" ersetzen? Java Basics - Anfänger-Themen 15
I Frage Thymeleaf -> Prefix / Suffix ändern? Java Basics - Anfänger-Themen 11
D Rekursions Probleme / frage Java Basics - Anfänger-Themen 4
T Frage zu Parse Java Basics - Anfänger-Themen 2
H Frage an die Profis Java Basics - Anfänger-Themen 4
J Eine konzeptionelle Frage zu OOP Java Basics - Anfänger-Themen 3
H Frage zur Ausgabe Java Basics - Anfänger-Themen 4
H Frage zu arithmetischen Operationen Java Basics - Anfänger-Themen 20
F Kurze Frage zu replace() Java Basics - Anfänger-Themen 19
JavaSchmecktLecker Polymorphie Frage zur Methodenüberschreibung Java Basics - Anfänger-Themen 21
J Frage zu einem "Taschenrechner" code Java Basics - Anfänger-Themen 9
B Erste Schritte Frage zu Instanzierung und Referenzen Java Basics - Anfänger-Themen 8
DoubleM Runtime.getRuntime().exec Frage Java Basics - Anfänger-Themen 2
J Eine theoretische Frage zur Praxis - JPanel oder Canvas Java Basics - Anfänger-Themen 5
O Frage: Formaler Typbezeichner? Java Basics - Anfänger-Themen 3
I BlueJ Queue Frage für Klausur Java Basics - Anfänger-Themen 2
N Verständnis Frage zu Variablen Java Basics - Anfänger-Themen 3
N Spezielle frage zum Comparator Java Basics - Anfänger-Themen 6
L Frage zum Array Java Basics - Anfänger-Themen 1
A Frage zum UML Design Java Basics - Anfänger-Themen 1
I Hilfe bei Klausur Frage Java Basics - Anfänger-Themen 8
izoards Drucken Frage zu FAQ Beitrag Java Basics - Anfänger-Themen 2
J Frage zu meinem Code (OOP) Java Basics - Anfänger-Themen 4
sserio Split() -> Regex Frage. Java Basics - Anfänger-Themen 7
A OCA Study Guide: 2. Frage aus Kapitel 3 Java Basics - Anfänger-Themen 9
sserio Date Library Frage Java Basics - Anfänger-Themen 9
Max246Sch Frage zu Währungsrechner Code Java Basics - Anfänger-Themen 2
sserio Frage zu HashMaps Java Basics - Anfänger-Themen 20
sserio Frage zu Threading - Multithreading Java Basics - Anfänger-Themen 2
sserio Frage zu Lambda Ausdrücken Java Basics - Anfänger-Themen 7
sserio Frage zu BigInteger Java Basics - Anfänger-Themen 1
D Frage bzgl. Enum-Handhabung Java Basics - Anfänger-Themen 16
xxx12 Frage Java Basics - Anfänger-Themen 2
I Generelle Frage zu Mikroservices (Spring Boot?), Docker... Java Basics - Anfänger-Themen 7
R Frage zu Methoden (Rückgabewert u. ohne.) Java Basics - Anfänger-Themen 2
A Frage zur programmierung Java Basics - Anfänger-Themen 12
M Frage zur Methode split der Klasse String Java Basics - Anfänger-Themen 32
R Input/Output Frage zu Java IO Java Basics - Anfänger-Themen 6
M Frage zu printWriter Java Basics - Anfänger-Themen 5
C Frage zu OLSMultipleLinearRegression Java Basics - Anfänger-Themen 31
KogoroMori21 Frage zum Euklidischen Algorithmus Java Basics - Anfänger-Themen 11
S Verständnis-Frage zu einer HÜ? Java Basics - Anfänger-Themen 1
F Frage betreff Programm mit dem man C++-Code in JAVA-Code übersetzen lassen kann Java Basics - Anfänger-Themen 2
L Frage zur Ticket Maschine Java Basics - Anfänger-Themen 1
J Frage zu OOP-Klassendiagramm Java Basics - Anfänger-Themen 8
OSchriever Frage zu Compiler Java Basics - Anfänger-Themen 8
H Frage zu Throw Exception Java Basics - Anfänger-Themen 2
TimoN11 Frage zu Java-Vererbung (Cast) Java Basics - Anfänger-Themen 5
Bademeister007 Hallo Leute ich hab eine Frage zur ArrayList Java Basics - Anfänger-Themen 8
F Frage betreff Programmierbücher zu Lagerverwaltung als Konsolenprogramm Java Basics - Anfänger-Themen 3
dieter000 Kurze Frage kann mir ejmand kurz diesen Code erklären, bzw wie man die zeilen erklärt und so Java Basics - Anfänger-Themen 1
I String.split regex Frage Java Basics - Anfänger-Themen 2
N Best Practice Frage zum MVC-Pattern Java Basics - Anfänger-Themen 2
dieter000 Frage zu einem Beispiel... Java Basics - Anfänger-Themen 5
J Frage zum Loggen Java Basics - Anfänger-Themen 18
J Methoden Frage: Array-Werte in anderer Methode ändern Java Basics - Anfänger-Themen 4
Zrebna Frage zum "Referenzen-konzept" in Java Java Basics - Anfänger-Themen 8
JD_1998 Array-Position aus einer Methode in einer anderen ausgeben (Kurze Frage) Java Basics - Anfänger-Themen 2
marcooooo Frage zu bestimmten Beispiel Java Basics - Anfänger-Themen 31
NeoLexx equals()-Methode Verständnis Frage anhand Code Beispiel Java Basics - Anfänger-Themen 22
N Input/Output Eine Frage über system.out.println. Java Basics - Anfänger-Themen 10
B Erste Schritte Learning Coding (!) Frage an erfahrene Programmierer. Java Basics - Anfänger-Themen 23
M konzeptuelle Frage: In welcher Klasse definiert man am Besten Methoden, die die Kommunikation mit dem User regeln? Java Basics - Anfänger-Themen 8
B Frage zum Code verständnis im Resultat Java Basics - Anfänger-Themen 10
C Exception-Frage Java Basics - Anfänger-Themen 3
J Eine Frage zur Schreibweise == ? : Java Basics - Anfänger-Themen 3
S Frage des Designs Java Basics - Anfänger-Themen 1
JavaTalksToMe Extends/Implements Frage Java Basics - Anfänger-Themen 3
pkm Frage zu Servletfunktion Java Basics - Anfänger-Themen 0
B Frage zur Währungsumrechnung Java Basics - Anfänger-Themen 3
S Allgemeine Frage über Generics und Vererbungen Java Basics - Anfänger-Themen 5
Kirby.exe Frage zur Verwendung von Interfaces Java Basics - Anfänger-Themen 6
D Frage zu Strings einer Exception Java Basics - Anfänger-Themen 4
L Wie frage ich ab, ob in einem Array, Werte doppelt vorkommen? Java Basics - Anfänger-Themen 4
D Frage zur IDE IntelliJ IDEA Java Basics - Anfänger-Themen 6
H Frage zum 2d Array Java Basics - Anfänger-Themen 1
N Frage zum Newton-Fraktal Java Basics - Anfänger-Themen 1
H Frage zu interfaces Java Basics - Anfänger-Themen 1
J Frage dazu Variablen klassenübergreifend zu verändern Java Basics - Anfänger-Themen 22
I Frage zu SkipList Java Basics - Anfänger-Themen 4
G Frage zu JScrollPane Java Basics - Anfänger-Themen 12
Kirby.exe Allgemeine Frage Java Basics - Anfänger-Themen 3
W Frage zu anonymen Klassen Java Basics - Anfänger-Themen 4
J Kleine Frage zu OOP Java Basics - Anfänger-Themen 371
S Frage Klasse und Objekte Java Basics - Anfänger-Themen 2
F Frage zu Iteratoren Java Basics - Anfänger-Themen 2
C Erste Schritte Frage zur ArrayList Java Basics - Anfänger-Themen 15
J Frage zur Vererbung Java Basics - Anfänger-Themen 1
H Frage zur ermittlung eines doppelte Paars aus Sotieralgorithmus Java Basics - Anfänger-Themen 4
H Frage zum Array Java Basics - Anfänger-Themen 17
G Schach -Frage 2- Maussteuerung Java Basics - Anfänger-Themen 7
G Schach in Java - Allgemeine Frage zur Architektur Java Basics - Anfänger-Themen 7

Ähnliche Java Themen

Neue Themen


Oben