Fibonacci Zahlen rekursiv Array

B

bruce00

Gast
Hallo liebe Community,

ich habe folgende Fragestellung:
Wir sollen ein Programm schreiben, das die Fibonacci Zahlen in einer rekursiv Methode berechnen soll, aber ohne dass die Werten immer wieder neu bestimmt werden müssen.
Es gilt:
F(n) = F(n-1) + F(n-2)
F(0)=F(1)=1

Verwenden Sie einen Array, der die bereits berechneten Werte speichert.(Den Array kann man auch zusätlich als Parameter übergeben)

Ich weiss, es gibt so viele Beiträge zu Fibonacci Zahlen und auch in diesem Forum. Ich bin alles durch und durch.
Auch diese Methode: Fibonacci Sequence - Recursion with memoization, habe ich auch durchgelesen. Aber es ist nicht die Fragestellung.

Ich kann die Zahlen rekursiv berechnen aber ich weiss nicht, wie man die bereits berechnete Werte in einem Array
abspeichern kann. Bin seit Stunden dran, aber ich krieg das nicht hin.
Das Problem ist mir klar. Die Berechnung wiederholt sich , und mit n großen Folgen wächst auch die Laufzeit exponential.

Ich bin soweit gekommen und hoffe, ihr könnt mir helfen.

Java:
public class Fibonacci
{
    public static void main(String[] args)
    {
        System.out.println(fibonacci(6));
    }

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

Nun meine Frage:
Wie speichere ich die Werte in den Array?
Mit meinen Lösungen bin ich nicht weiter gekommen, daher steht da nichts.

Danke im Voraus!
Bruce
 

franky27

Bekanntes Mitglied
Na du erstellst dir ein Array mit der gewünschten Anzahl an Zahlen zB
Java:
int []zahlen = new int[20];
Dann speicherst du in einer for Schleife deine Ergebnisse in dem array ab
Java:
 for (int i = 0; i<zahlen.length; i++){
    	zahlen[i] = fibonacci(i);
    }
Musst halt aufpassen das du im int Wertebereich bleibst, oder halt den Datentyp
ändern das du auch grössere Ergebnisse speichern kannst. Wird ab einer gewissen
Grösse aber sowieso ne ganze Weile dauern.
 
B

bruce00

Gast
Java:
public class Fibonacci
{
    public static void main(String[] args)
    {
        System.out.println(fibonacci(6));
    }

    public static int fibonacci(int n)
    {
        int []zahlen = new int[n];
        
            for (int i = 0; i<zahlen.length; i++){
                zahlen[i] = fibonacci(i-1) + fibonacci(i - 2);
            }

            return zahlen[n];
    }
}

Mit For Schleife hatte ich auch gemacht. Aber da kommt, IndexOutOFBound Fehlermeldung.
Muss überprüfen, ob die Werte schon berechnet sind. Und so funktioniert es nicht. Denn fib(0) und fib(1) können nicht berechnet werden.
 
B

bruce00

Gast
Also die Zwischenergebnisse speichern. z.B fib(5) = fib(4) + fib(3). fib(4) = fib(3) + fib(2) Wie man hier sieht wird ja fib(3) zweimal berechnet.
Diese sollen wir speichern. Das Ergebnis soll in einem Array gespeichert werden.
Java:
public class Fibonacci
{
    public static void main(String[] args)
    {
        System.out.println(fibonacci(6));
    }

    public static int fibonacci(int n)
    {
        int []zahlen = new int[n];

            for (int i = 2; i <zahlen.length; i++){
                if(i == 0){//fib(0) = 0
                    zahlen[0] = 0;
                    return zahlen[0];
                }
                if(i == 1){//fib(1) = 1
                    zahlen[1] = 1;
                    return zahlen[1];
                }
                else {
                    if(n != 0) { //bereits berechnete nicht rechnen
                        zahlen[i] = fibonacci(i - 1) + fibonacci(i - 2);
                    }
                }
            }

            return zahlen[n];
    }
}

Bin gerade hier. Krieg wieder IndexOutOfBounds.
 
B

bruce00

Gast
Ja richtig. Habe ich versucht aber nicht hingekriegt.

Ich habe umgesetzt

Java:
public class Fibonacci {
    public static int fib(int n) {
        int []fibs = new int[n + 1];

        if(n == 0)
        fibs[0] = 0;
        if(n == 1)
        fibs[1] = 1;

        if (fibs[n] == 0 && n > 0) { //Wert nicht im Array
            int newFib = fib(n-1) + fib(n-2); //berechnen
            fibs[n] = newFib; //abspeichern
        }
        return fibs[n];
    }

    public static void main(String[] args) {
        System.out.println(fib(40));
    }
}
Bei n = 40 dauert es wieder zulange,

Das Problem ist einfach die rekursive Mehode. Bei normalen hätte ich schon längst das hingekriegt. Ich gehe im Compiler die
rek Methode durch. Ich kenne das Verhalten von dieser Methode nicht,
 
Zuletzt bearbeitet von einem Moderator:

Enceladus271

Bekanntes Mitglied
Der Fehler besteht darin, dass du das Array als lokale Variable erzeugst. Dadurch wird bei jedem Aufruf der Methode das Array neu erzeugt (und ist jedesmal wieder leer). Du muss statt dessen das Array als Klassenvariable verwenden.
 
B

bruce00

Gast
Nun jetzt gebe ich mal einen Feedback. Ich habe mich ausführlich mit Fibonacci Zahlen beschäftigt und habe selber versucht eine Lösung zu finden, die ich SELBST verstehe. Nun hab ich leider nichts gehört, was meiner Frage irgendwie etwas beträgt.

Ich bin euch dankbar für eure Antworten aber das ist dürftig. ich will auch keine vorgefertigte Lösung, sondern eine Idee. Die habe ich bis jetzt nicht gekriegt.
 

franky27

Bekanntes Mitglied
Dürftig?
Also jetzt mal im Ernst, dass ist schon nahe an der Grenze zu unverschämt. Du machst uns dafür verantwortlich das du keine Lösung findest die DU verstehst? Was willst du denn eigentlich? Du hast eine Lösung fehlerhaft umgesetzt, Enceladus hat dich darauf aufmerksam gemacht, was dein Fehler ist. Wenn eine Lösung + Erklärung was bei dir noch falsch ist nichts ist, was zu deiner Frage IRGENDETWAS beiträgt, dann solltest du vielleicht lernen wie man richtig Fragen stellt.
 
B

bruce00

Gast
Hallo zusammen,

Verseht mich nicht falsch. İch habs probiert mit den Lösungen aber der Fehler besteht wieder. Entschuldigt mich bitte, wenn es böse rübergekommen ist.

İch habe die Lösungen umgesetzt und wieder und wieder Fehlermeldung bekommen. ich habe mich auch bedankt aber das hat nicht gereicht, um Fehlerfrei zu kompilieren.
Freundliche Grüsse

Peace ;)
 
Zuletzt bearbeitet von einem Moderator:

Enceladus271

Bekanntes Mitglied
Java:
public class Fibonacci {
    private static int[] fibs = new int[50];

    public static int fib( int n ) {

        if ( n == 0 )
            fibs[0] = 0;
        if ( n == 1 )
            fibs[1] = 1;

        if ( fibs[n] == 0 && n > 0 ) { // Wert nicht im Array
            System.out.println( "Berechne fib " + n );
            int newFib = fib( n - 1 ) + fib( n - 2 ); // berechnen
            fibs[n] = newFib; // abspeichern
        }
        return fibs[n];
    }

    public static void main( String[] args ) {
        System.out.println( fib( 40 ) );
        System.out.println( fib( 45 ) );
    }
}

Habe ausgehend vom letzen Code den du gepostet hast den Fehler behoben auf den ich hingewiesen habe. Hab noch zusätzlich eine Ausgabe auf der Konsole gemacht. Dadurch sieht man das einmal berechnete Ergebnisse nicht nochmal berechnet werden, sondern aus dem Array genommen werden. Funktioniert also.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
jhCDtGVjcZGcfzug Fibonacci Zahlen rekursiv und iterativ Java Basics - Anfänger-Themen 21
S Fibonacci Zahlen rekursiv Java Basics - Anfänger-Themen 1
B Fibonacci Zahlen dynamische Programmierung Java Basics - Anfänger-Themen 7
A Fibonacci Zahlen Java Basics - Anfänger-Themen 1
K Fibonacci Zahlen Java Basics - Anfänger-Themen 3
J Fibonacci Zahlen berechnen Java Basics - Anfänger-Themen 3
C Fibonacci Zahlen Java Basics - Anfänger-Themen 7
J Ausgabe der fibonacci Zahlen Java Basics - Anfänger-Themen 4
0 Fibonacci Zahlen seeeehr schnell berechnen Java Basics - Anfänger-Themen 9
K Fibonacci Zahlen Java Basics - Anfänger-Themen 2
K Programmieren von den ersten 70 Fibonacci-Zahlen Java Basics - Anfänger-Themen 2
G Iterativer Algorithmus zur Berechnung der Fibonacci Zahlen Java Basics - Anfänger-Themen 1
P Fibonacci-Zahlen Java Basics - Anfänger-Themen 6
S Abwandlung der Fibonacci Folge Java Basics - Anfänger-Themen 3
T Fibonacci mit einer Hilfsmethode berechnen Java Basics - Anfänger-Themen 10
123456789sssssaaaa Which is the best way to Print Fibonacci Series in Java? Java Basics - Anfänger-Themen 3
J Fibonacci-Reihe Java Basics - Anfänger-Themen 12
G Fibonacci Zahlenreihe Fehler Java Basics - Anfänger-Themen 4
D Fibonacci overflow integer Java Basics - Anfänger-Themen 8
N Dynamisches Programmieren/Fibonacci Java Basics - Anfänger-Themen 1
V Fibonacci Folge Java Basics - Anfänger-Themen 4
M Methoden Fibonacci-Folge Java Basics - Anfänger-Themen 6
J Fibonacci -Folge rekursiv berechnen Java Basics - Anfänger-Themen 18
P Fibonacci -Verallgemeintert Java Basics - Anfänger-Themen 2
K Methoden Fibonacci in Array mit rekursiver Methoden Java Basics - Anfänger-Themen 19
M Fibonacci rekursiv mittels Cache Java Basics - Anfänger-Themen 17
T Stack Overflow - Rekursive Fibonacci Java Basics - Anfänger-Themen 10
M Fibonacci-Folge mit while-Schleife Java Basics - Anfänger-Themen 4
P fibonacci - do while Statement Logik Fehler Java Basics - Anfänger-Themen 5
A Fibonacci-numbers Java Basics - Anfänger-Themen 9
K Rekursion Fibonacci Java Basics - Anfänger-Themen 3
Z Fibonacci rekursiv meine Erklärung stimmt so? Java Basics - Anfänger-Themen 2
Z Fibonacci Array Erklärung Java Basics - Anfänger-Themen 5
A Gerade Terme der Fibonacci-Folge aufsummieren Java Basics - Anfänger-Themen 12
M Fibonacci, Fakultaet, GGT Java Basics - Anfänger-Themen 9
S Fibonacci Folge Java Basics - Anfänger-Themen 34
D Fibonacci Java Basics - Anfänger-Themen 11
M Fibonacci-Linear und Rekursiv Java Basics - Anfänger-Themen 14
W Fibonacci Zahlenberechnung Java Basics - Anfänger-Themen 9
X Fibonacci mit durchschnittlicher Zeit Java Basics - Anfänger-Themen 5
I Fibonacci-Folge , direkter Weg. Java Basics - Anfänger-Themen 5
G Fibonacci Algorithmus Java Basics - Anfänger-Themen 22
S Fibonacci Rückrechnung! Java Basics - Anfänger-Themen 5
G fibonacci was stimmt an meinem code nicht? Java Basics - Anfänger-Themen 2
S Fibonacci Zahlenvergeich Java Basics - Anfänger-Themen 6
onlyxlia Anzahl Random Zahlen mit Scanner abfragen und in Array speichern Java Basics - Anfänger-Themen 10
Ü Java Array - Buchstaben als Zahlen ausgeben Java Basics - Anfänger-Themen 22
P Aus Text Datei nur Zahlen übernehmen Java Basics - Anfänger-Themen 13
K Warum werden immer noch doppelte Zahlen ausgegeben ? Java Basics - Anfänger-Themen 13
M negative Zahlen bei Intervallen Java Basics - Anfänger-Themen 10
XWing Doppelte Zahlen im Array Java Basics - Anfänger-Themen 8
M 3 Zahlen miteinander vergleichen Java Basics - Anfänger-Themen 18
J Taschenrechner mit mehr als 2 Zahlen. Java Basics - Anfänger-Themen 18
O Zahlen aus einem char-array per char + Zeichen addieren Java Basics - Anfänger-Themen 2
B Alle Zahlen finden, die 3 bestimmte Ziffern enthalten? Java Basics - Anfänger-Themen 9
K Java gleicher Wert von Zahlen? Java Basics - Anfänger-Themen 5
I aus 2 random zahlen soll nur die ungerade summe der beiden genommen werden. Java Basics - Anfänger-Themen 13
J Operatoren Zahlen addieren Java Basics - Anfänger-Themen 13
B Threads Counter mit ungeraden Zahlen Java Basics - Anfänger-Themen 32
JavaBeginner22 Java 2 Zufalls zahlen generieren. Java Basics - Anfänger-Themen 11
X Wie kann man ein Regex erstellen, die 8-Bit-Binär-Zahlen darstellen. Java Basics - Anfänger-Themen 1
M Stream mit den ersten n natürlichen Zahlen Java Basics - Anfänger-Themen 4
D Größtes Palindrom Produkt aus zwei dreistelligen Zahlen Java Basics - Anfänger-Themen 60
T Methode, die prüft ob in einem Int-Array maximal 2 Zahlen enthalten sind, die größer als ihr Vorgänger sind Java Basics - Anfänger-Themen 5
sserio Befreundete Zahlen Java Basics - Anfänger-Themen 7
AhmadSlack Verzweigungen zahlen multiplizieren Java Basics - Anfänger-Themen 4
padde479 Array Multiplikation der ersten n Zahlen Java Basics - Anfänger-Themen 7
U Lotto-Zahlen App Java Basics - Anfänger-Themen 34
berserkerdq2 Wie würde man einen regulären Ausdruck in Java schreiben, der prüft, dass zwei bestimtme Zahlen nicht nebeneinadner sind? Java Basics - Anfänger-Themen 3
H Arrays: Größten Zahlen Unterschied herausfinden Java Basics - Anfänger-Themen 20
bluetrix Programmieren eines Bots für Zahlen-Brettspiel Java Basics - Anfänger-Themen 9
J Zahlen bis zu einem bestimmten Grenzwert ausgeben Java Basics - Anfänger-Themen 11
00111010101 Objektorientiertes Programmieren mit Vererbung (Zahlen in Array verschwinden) Java Basics - Anfänger-Themen 3
P Zweidimensionales Array als Tabelle mit befüllten Zahlen Java Basics - Anfänger-Themen 10
W Wie ziehe ich von einer bestimmten Zahl, Zahlen ab, bis mein Ergebnis null beträgt? Java Basics - Anfänger-Themen 10
emx-zee Erste Schritte NullPointerException, Array mit zufälligen Zahlen füllen Java Basics - Anfänger-Themen 2
W Bestimmte Zahlen bei Math.random ausschließen? Java Basics - Anfänger-Themen 31
K Erste Schritte "Taschenrechner" zeigt keine Komma Zahlen an. Java Basics - Anfänger-Themen 8
P Drei Zahlen eines Würfelspiels auswerten Java Basics - Anfänger-Themen 7
H Häufigkeit von Zahlen ermitteln Java Basics - Anfänger-Themen 23
sashady Zahlen rekursiv zerlegen und Ziffern addieren Java Basics - Anfänger-Themen 38
H Zahlen kürzen Java Basics - Anfänger-Themen 2
ansystin Teilerfremde Zahlen ausgeben + Zahlenausgabe speichern Java Basics - Anfänger-Themen 3
B Häufigkeit einzelner Zahlen in einem Array Java Basics - Anfänger-Themen 6
nevel Programm für die Summer der Zahlen 1- 1ß Java Basics - Anfänger-Themen 12
H Eingegebene Zahlen mit Array ausgeben Java Basics - Anfänger-Themen 18
I 12 Spalten von jeweils 30 Zahlen in Konsole ausgeben Java Basics - Anfänger-Themen 6
R Array mit Unter- und Obergrenze ganze Zahlen dazwischen erscheinen nicht Java Basics - Anfänger-Themen 1
OZAN86 For Schleife von 1-50 die Zahlen werden durch ein Komma getrennt Java Basics - Anfänger-Themen 10
Bademeister007 Operatoren Alle Zahlen einer ArrayList die durch 5 teilbar ist Java Basics - Anfänger-Themen 2
mhmt_03 dafür sorgen, dass im JTextfield nur zahlen eingebbar sind Java Basics - Anfänger-Themen 9
Ianatrix Zahlen von a bis b berechnen Java Basics - Anfänger-Themen 7
P Wie kann ich die Zahlen dieses Arrays dividieren? Java Basics - Anfänger-Themen 2
P Nutzer entscheiden lassen, wie viele Zahlen dieser in ein Array eingeben möchte. Java Basics - Anfänger-Themen 6
T Bestimmte Zahlen ausgeben mit einer whilfe Schleife Java Basics - Anfänger-Themen 21
H Alle Geraden zahlen bis 10 ausgeben Java Basics - Anfänger-Themen 11
java3690 Liste mit zufälligen zahlen füllen Java Basics - Anfänger-Themen 27
macle Rekursive String Methode, Gerade Zahlen rausfiltern Java Basics - Anfänger-Themen 10
M Regex nur Zahlen und Punkt zulassen, Keine Eingabe(Leeres TextFeld) nicht zulassen Java Basics - Anfänger-Themen 6
L Mit Zahlen im String rechnen Java Basics - Anfänger-Themen 19

Ähnliche Java Themen

Neue Themen


Oben