Einfache Rekursion

Status
Nicht offen für weitere Antworten.

wyldstyle

Aktives Mitglied
Hallo, ich versuche derzeitig mir ein kleines Programm für die Uni zu schreiben. Wir machen in Analyis derzeitige rekursive Folgen und ich wollte mir eine Folge mal ausrechnen lassen, stoße da aber auf ein Problem. Meines erachtens ist die rekursionsformel korrekt.

Die Funktion lautet: x1=42, xn+1=(5/7)*xn!

Also 42,30,(150/7),(750/49),(3750/345)... etc.

Mein Code sieht so aus:
Java:
static int recursive (int n){
      System.out.println(n);
       if ( n == 1){
          return 42;
        }else{
            return (recursive(n-1)*(5/7));
        }
   }

Wo ist da der Wurm drin? Ich bekomm nie das richtige Ergebnis und fidne den Logikfehler einfach nicht!

//Edit: Fehler in der Folge korrigiert!
 
Zuletzt bearbeitet:

nw90

Mitglied
Habs jetzt nur überflogen, aber könnte dadran liegen, dass du int als Rückgabetyp hast. Da du ja mit Brüchen rechnest, solltest du float verwenden.
 
G

Gast

Gast
Deine oben beschriebene Folge ist falsch
x1 = 42, x2 = 30, x3 = 150/7 x4 = 750 / 49 ...
 

nw90

Mitglied
So sollte es gehen:
Java:
static float recursive (int n){
      System.out.println(n);
       if ( n == 1){
          return 42;
        }else{
            return recursive(n-1)*  5 / 7;
        }
   }
 
Zuletzt bearbeitet:

wyldstyle

Aktives Mitglied
Super, das geht. Ich frag mich nur wo der Unterschied zu meienr Version ist ausser Leerzeichen? Der Ausruck sollte doch gleich ausgewertet werden?
 

nw90

Mitglied
Der Unterschied liegt darin, dass ich die Klammern um 5/7 weggelassen habe. Wenn du die Klammern lässt, liefert der für (5/7) immer 0, weshalb das ganze Ergebnis 0 wird. Ich weiß nicht genau warum - vermutlich sieht er das als Integer an und daher ist für ihnr 5/7=0. Ich hatte schonmal so ein Problem und daher kenne ich diese "Eigenart" noch.
Wenn du übrigens einen float i definiert hättest mir i = 5/7 und dieses statt (5/7) in return geschrieben hättest, wäre es ebenso nicht gegangen.
 

musiKk

Top Contributor
[c]5f/7[/c] würde es z. B. auch tun. Wenn zwei ganze Zahlen dividiert werden, kommt wieder eine ganze Zahl heraus. Die Stellen nach dem Komma werden abgeschnitten. Ist aber ein Teil reell, wird auch das Ergebnis reell.
In der Version von nw90 weiß der Compiler, dass die Methode float zurück gibt. Das wird multipliziert mit einer ganzen Zahl (5), was wieder float ist. Analog bei der Division (7).
 

madboy

Top Contributor
Java:
System.out.println(5/7); //0
System.out.println(5f/7); //0.7142857142857143
System.out.println(5.0/7); //0.7142857142857143
Das kleine f, genau so wie 5.0 zeigt dem Compiler dass du eine Gleitkommazahl (float in dem Fall, d stünde für double) haben willst statt einem int.
 

wyldstyle

Aktives Mitglied
Ok, vielen dank für die Aufklärung, da wär ich so schnell nicht drauf gekommen!

Ich mach dann an dieser Stelle dicht, herzlichen Dank nochmal!
 

Painii

Bekanntes Mitglied
Wo wir beim lernen sind:
Kann mir mal jemand einen Anwendungsfall sagen wo float besser ist als double?
Bisher hab ich immer nur double genommen und bin so durchgekommen...
 

Landei

Top Contributor
Wo wir beim lernen sind:
Kann mir mal jemand einen Anwendungsfall sagen wo float besser ist als double?
Bisher hab ich immer nur double genommen und bin so durchgekommen...

Na ja, float nimmt weniger Platz weg und float-Berechnung gehen schneller. Deshalb basieren z.B. 3D-Engines (Java3D, JME...) mit ihren aufwendigen Vektor-, Matrizen- und Quaternionenberechnungen auch auf float und nicht auf double. Prinzipiell: Wenn es nicht auf den letzten Fitzel Performance oder Speicherplatz ankommt, bleib bei double.
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
K Einfache Rekursion - Wert wird nicht in Variable gespeichert Java Basics - Anfänger-Themen 7
B einfache Rekursion Java Basics - Anfänger-Themen 9
monsterherz einfache Methode mit Fehler den ich nicht finde Java Basics - Anfänger-Themen 21
I Erste Schritte Einfache Datenbank-Webseite erstellen als Nicht-IT-lerin Java Basics - Anfänger-Themen 24
B Einfache OCR zur Zahlenerkennung? Java Basics - Anfänger-Themen 6
M Einfache Datenfilterung Java Basics - Anfänger-Themen 15
D Beim Programmieren auf die Logisch einfache Lösung kommen. Java Basics - Anfänger-Themen 17
H Einfache Frage zur Punktnotation objektname.methode(wert) Java Basics - Anfänger-Themen 2
B Einfache HSQLDB? (lock acquisition failure) Java Basics - Anfänger-Themen 2
B Threads Thread sleep() Method einfache Frage Java Basics - Anfänger-Themen 8
O Ganz einfache Frage - Array Java Basics - Anfänger-Themen 5
E Einfache Java Verschlüsselung Java Basics - Anfänger-Themen 4
J Einfache Frage zu "null" Java Basics - Anfänger-Themen 2
J Einfache pub/sub Lösung mit ausführlicher Doku Java Basics - Anfänger-Themen 5
R Gibt es Eine einfache Programierung dieser Methoden Java Basics - Anfänger-Themen 8
K einfache Kombinatorik Java Basics - Anfänger-Themen 4
M Erste Schritte Einfache Aufzugssteuerung programmieren - Anfänger Java Basics - Anfänger-Themen 2
D Eine einfache Verschlüsselung schreiben Java Basics - Anfänger-Themen 3
B in einem abstrakten Set ,Elemente einer einfache verkettete List epeichern Java Basics - Anfänger-Themen 13
X Einfache Frage; wie soll ich die spezielle float var speichern? Java Basics - Anfänger-Themen 2
J Einfache einbindung eines Bildes in ein Applet Java Basics - Anfänger-Themen 4
D Klassen Gesucht: Einfache Beispiel-Klasse für einen Datentyp Java Basics - Anfänger-Themen 7
K Möglichkeiten um eine einfache Animation darzustellen Java Basics - Anfänger-Themen 7
L Einfache Lineare Suche Java Basics - Anfänger-Themen 7
P Erste Schritte Einfache For Schleife Java Basics - Anfänger-Themen 10
M Einfache Java Operation, cheggs net Java Basics - Anfänger-Themen 2
V Erste Schritte Einfache Rechnung mit Exponenten Java Basics - Anfänger-Themen 3
G einfache Leet-Übersetzung implementieren und benutzen Java Basics - Anfänger-Themen 14
M Einfache und Doppelte Operatoren Java Basics - Anfänger-Themen 3
E Einfache For-Schleife macht nicht was sie soll Java Basics - Anfänger-Themen 2
shiroX OOP Türme von Hanoi - einfache grafische Ausgabe Java Basics - Anfänger-Themen 2
C Extrem einfache Aufgabe falsch beantwortet :$ Java Basics - Anfänger-Themen 6
Z Super einfache Frage For-Schleife im Detail Java Basics - Anfänger-Themen 3
N Potenzierung durch einfache Operatoren Java Basics - Anfänger-Themen 13
H Einfacher Editor, Einfache Handelsanweisungen Java Basics - Anfänger-Themen 2
H Sehr einfache Java-Programme Java Basics - Anfänger-Themen 24
H Einfache Client/Server-Kommunikation Java Basics - Anfänger-Themen 16
-horn- Einfache graphische Darstellung von 3D Koordinaten für Flugbahnen? Java Basics - Anfänger-Themen 4
B Einfache jsp Seite darstellen Java Basics - Anfänger-Themen 9
G Einfache if-Abfrage der Main-Argumente Java Basics - Anfänger-Themen 3
J Einfache Designfrage Java Basics - Anfänger-Themen 4
R Methoden Einfache Loops? Java Basics - Anfänger-Themen 8
E einfache Frage zu private Java Basics - Anfänger-Themen 26
R Sehr einfache möglichkeit ArrayList oder Array zu initialisieren? Java Basics - Anfänger-Themen 8
F Einfache Klassen für Datum und Zeit Java Basics - Anfänger-Themen 3
Spin Einfache Anfänger Frage setVisible von Panels Java Basics - Anfänger-Themen 5
E OOP einfache Array Aufgabe mit jUnit Java Basics - Anfänger-Themen 5
D einfache Quizfrage programmieren Java Basics - Anfänger-Themen 11
B Einfache Applets für Webseite Java Basics - Anfänger-Themen 10
U Einfache Aufgabe Java Basics - Anfänger-Themen 5
E Einfache Frage zur Parameterübergabe in Methoden Java Basics - Anfänger-Themen 8
M einfache Übungsaufgaben gesucht Java Basics - Anfänger-Themen 7
M Einfache Rechnung(R=U/I) Java Basics - Anfänger-Themen 12
D Wohl eine einfache Frage... Java Basics - Anfänger-Themen 2
W Einfache Passwortabfrage funktioniert nicht Java Basics - Anfänger-Themen 3
P einfache GUI-Elemente Java Basics - Anfänger-Themen 10
F Vererbung (einfache Frage) Java Basics - Anfänger-Themen 5
S 2 Einfache Fragen (Exception Breakpoint, Konstruktor) Java Basics - Anfänger-Themen 4
L einfache Klasse erstellen Java Basics - Anfänger-Themen 16
M kleine und einfache Verständnisfrage Java Basics - Anfänger-Themen 3
P Einfache Bedingung (?) in Java Java Basics - Anfänger-Themen 3
T Einfache Textausgabe .java unter OS X Java Basics - Anfänger-Themen 13
A [Hilfe] einfache Aufgabe Java Basics - Anfänger-Themen 26
A Einfache java Verschlüsselung HILFE Java Basics - Anfänger-Themen 3
M einfache java application Java Basics - Anfänger-Themen 4
S Kann einfache Texteingabe nicht auswerten! Java Basics - Anfänger-Themen 3
M einfache frage zum Jdk-Compiler Java Basics - Anfänger-Themen 3
Spin einfache Frage zu Klassen Java Basics - Anfänger-Themen 12
J einfache Tastendrücke in einem JFrame abfragen Java Basics - Anfänger-Themen 2
C "einfache" If-Abfrage Java Basics - Anfänger-Themen 15
H Einfache Ausgabe eines Arrays in einen File Java Basics - Anfänger-Themen 8
F Einfache Liste hinten was einfügen Java Basics - Anfänger-Themen 3
L Einfache Umrechnung Java Basics - Anfänger-Themen 2
D Einfache Funktion zum kaufmännischen runden Java Basics - Anfänger-Themen 8
K einfache Multiplikation Java Basics - Anfänger-Themen 6
S Einfache Rechnung mit Schleife Java Basics - Anfänger-Themen 10
G einfache Swing-GUI Java Basics - Anfänger-Themen 3
F Einfache Tastatureingabe Java Basics - Anfänger-Themen 2
L [gelöst] Einfache Aufgabe, läuft aber nicht. Java Basics - Anfänger-Themen 8
S "einfache Klassengeschichten" keine Fehler, läuft Java Basics - Anfänger-Themen 2
R Einfache MVC-Uhr. MVC richtig umgesetzt? [Überarbeitet] Java Basics - Anfänger-Themen 5
A Einfache Frage zur Mehrfachvererbung Java Basics - Anfänger-Themen 3
G Einfache Berechnung liefert falsches Ergebnis Java Basics - Anfänger-Themen 2
J eine einfache liste Java Basics - Anfänger-Themen 17
D Suche einfache Übungsaufgaben für den JavaCreator! Java Basics - Anfänger-Themen 5
R Einfache Messagebox Java Basics - Anfänger-Themen 9
N einfache Adressdatenbank in Textdatei Java Basics - Anfänger-Themen 8
I einfache Wiedergabe Java Basics - Anfänger-Themen 2
B Warum hat dieser einfache Algorithmus lineare Laufzeit? Java Basics - Anfänger-Themen 3
U "Einfache Verschlüsselung" Java Basics - Anfänger-Themen 17
K einfache Umfang und Flächenberechnung mit interfaces Java Basics - Anfänger-Themen 3
M Einfache HTML Mail versenden , suche Beispiel Java Basics - Anfänger-Themen 5
L MVC-einfache frage Java Basics - Anfänger-Themen 13
M einfache schleife Java Basics - Anfänger-Themen 7
M Einfache Schleife Java Basics - Anfänger-Themen 4
K Verstehe Rekursion nicht ganz Java Basics - Anfänger-Themen 7
P Frage zu Rekursion und Backtracking Java Basics - Anfänger-Themen 2
DiyarcanZeren Rekursion in Java Java Basics - Anfänger-Themen 5
M Variablen Rekursion mit 2 Parameteren Java Basics - Anfänger-Themen 4
sserio Rekursion größten Primfaktor finden funktioniert nicht Java Basics - Anfänger-Themen 8

Ähnliche Java Themen

Neue Themen


Oben