Array nach Wert prüfen rekursiv

bindankbar

Mitglied
Hi sagen wir mal ich habe einen COde der so aussieht:
Java:
 public static int calculateBinomialCoefficient (int n, int k)
   {
      if (k == 1)
         return n;
      else if (n >= k && k == 0)
         return 1;
      else
       return (n * calculateBinomialCoefficient(n - 1, k - 1) / k);
 
   }
}

Nun hat mein Prof gemeint, dass die rekursion nicht linear ist und zu vielen gleichen Aufrufen mit gleichen Parameterkombis führt. EIne Möglichkeit damit das besser läuft ist es berechenete Binomialkoeffizienten in einem zwei dimensionalen Array zu speichern und vor einem rekursiven Aufruf zu prüfen, ob die Lösung bereits 1x exisitert hat. Wenn ja soll ich den Wert vom Array ausgeben, wenn nicht soll ich den Wert im Array speichern. Einen Array haben wir schon gegeben, mit der perfekten Länge. Dann habe ich mir überlegt, dass man das so umschreiben kann:

Java:
 public static int calculateBinomialCoefficient (int n, int k)
  {
   if (k == 1)
     return n;
   else if (n >= k && k == 0)
     return 1;
  else{
        for (int a=0; a<array.length;a++)
           {
            for(int b=0; b<array.length;b++)
              {
                if (array[a][b]==(n * calculateBinomialCoefficient(n - 1, k - 1) / k))
               {
                    return array[a][b];
                }else if(array[a][b]==0)
                {
                    array[a][b]=(n * calculateBinomialCoefficient(n - 1, k - 1) / k);
                    return (n * calculateBinomialCoefficient(n - 1, k - 1) / k);
                }
            }
        }
    }

Das ist jetzt keine Hausaufgabe oder so, sondern freiwillig, bei mir ist es so, wenn ich korrekten Code sehe, kann ich nachvollziehen warum etwas wie war und es nächstes Mal richtig. Und ich habe das als Übung versucht noch umzusetzen aber seit paar Stunden keine Ahnung wo der Fehler ist. Wäre cool, wenn das einer vielleicht verbessern kann, damit ich die korrekte logischen Schlüsse zusammenfassen kann und mir merken kann, warum man es so macht und es verstehe.

Sorry das die Tabs beim zweiten bisschen falsch sind, habe das eigentlich versucht korrekt zu machen, aber bin da total dumm online, bei meinem muss ich nur Tab drücken und alles ist richtig eingerückt, das manuell zu machen ist doch komplexer als gedacht.
 

bindankbar

Mitglied
Dann hast Du ihm aber einen anderen Code gezeigt.
Das ist auch nicht der code von ihm, seinen code dürfen wir nicht posten, aber ist sehr ähnlich, also eigentlich das gleiche nur bisschen anders. ALso hatten da was im ersten Teil vorgegeben, was man noch Ergänzen musste,bei mir kommt auch das richtige Ergebnis, er meint, dass das so so sei, also nicht linear.
 

mihe7

Top Contributor
Der Punkt ist, dass in einer nicht-linearen Rekursion der Rekursionsaufruf mehrfach ausgeführt werden kann. Daher macht es keinen Sinn, sich darüber anhand dieses Codes (lineare Rekursion, endrekursiv) Gedanken zu machen.

Im Prinzip solltest Du einfach genau(!) das machen, was der Prof. geschrieben hat. Und in der Regel sieht das so aus, dass Du mit dem zweidimensionalen Array natürlich unmittelbar auf die Lösung zugreifen kannst (die Indizes entsprechen Deinen Parametern). Schleifen solltest Du da nicht benötigen.
 

bindankbar

Mitglied
Der Punkt ist, dass in einer nicht-linearen Rekursion der Rekursionsaufruf mehrfach ausgeführt werden kann. Daher macht es keinen Sinn, sich darüber anhand dieses Codes (lineare Rekursion, endrekursiv) Gedanken zu machen.

Im Prinzip solltest Du einfach genau(!) das machen, was der Prof. geschrieben hat. Und in der Regel sieht das so aus, dass Du mit dem zweidimensionalen Array natürlich unmittelbar auf die Lösung zugreifen kannst (die Indizes entsprechen Deinen Parametern). Schleifen solltest Du da nicht benötigen.
Also leider keine Ahnung. Aber habs hinbekommen, hat nur bisschen gedauert
 

mihe7

Top Contributor
Nehmen wir mal die Fibonacci-Folge. Wir wollen den Wert des n-ten Glieds bestimmen:
Java:
public int fibonacci(int n) {
    if (n < 1) return 0;
    if (n < 2) return 1;
    return fibonacci(n-1) + fibonacci(n-2);
}

Hier hast Du eine nicht-lineare Rekursion, weil Du fibonacci mehrfach rekursiv aufrufst. Betrachtet man im "Uraufruf" den linken Term fibonacci(n-1), dann wird bei dessen Ausführung im linken Term fibonacci(n-2) aufgerufen. Also genau das, was im Uraufruf dem rechten Term entspricht. Heißt also: hier werden sehr viele Berechnungen wiederholt.

Das lässt sich beschleunigen mit einem Array. Beim rekursiven Abstieg im linken Term werden alle unbekannten Folgeglieder zwischen n-1 und 2 (inkl.) berechnet. Speichert man die Werte in einem Array, kann man den Wert von fibonacci(n-2) unmittelbar aus diesem Array erhalten.

Java:
public int fibonacci(int n) {
    values = new int[n+1];
    values[1] = 1;
    return fib(n);
}

private int fib(int n) {
    if (n < 1) return 0;
    if (n < 2) return 1;
    int fib1 = fib(n-1);
    int fib2 = values[n-2];
    values[n] = fib1 + fib2;
    return values[n];
}
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
A String Array: Suche nach Name -> Wert? Java Basics - Anfänger-Themen 3
B Array nach Elementwerten sortieren? Java Basics - Anfänger-Themen 1
javaluke Erste Schritte Array nach Datentyp sortieren Java Basics - Anfänger-Themen 16
O 2D-Array nach einer Spalte sortieren Java Basics - Anfänger-Themen 22
D Input/Output fehlerhafter Algorithmus zum Ersetzen von Array-Werten nach logischem Schema Java Basics - Anfänger-Themen 1
Ellachen55 Wie nach häufigste Werte im Array suchen? Java Basics - Anfänger-Themen 2
R Benutzereingaben als Array abspeichern nach Programmstart Java Basics - Anfänger-Themen 5
F Array nach Objektattribut durchsuchen Java Basics - Anfänger-Themen 6
M Array nach String durchsuchen und zurückgeben Java Basics - Anfänger-Themen 16
O Array nach gleichen Zahlen prüfen und ausgeben Java Basics - Anfänger-Themen 6
M Array nach Zehnen durchsuchen. Java Basics - Anfänger-Themen 25
B Element in Array nach unten verschieben Java Basics - Anfänger-Themen 11
B Methoden Element aus einem Array löschen, Rest nach vorne verschieben? Java Basics - Anfänger-Themen 4
C eine diagonale von rechts nach links im 2d-array Java Basics - Anfänger-Themen 1
W Array nach String durchsuchen und Ausgeben Java Basics - Anfänger-Themen 8
C Abfrage nach einem Bild im Array Java Basics - Anfänger-Themen 9
J Array nach häufigkeit sortieren Java Basics - Anfänger-Themen 4
S Strings im Array nach Namen sortieren Java Basics - Anfänger-Themen 11
E Arrayeintrag nach Index löschen und Array kürzen Java Basics - Anfänger-Themen 3
B Object in Array nach Prüfung löschen Java Basics - Anfänger-Themen 13
L Array - Nach 2 gleichen Werten stoppen Java Basics - Anfänger-Themen 5
W Elemente in einem Array nach 'oben' verschieben Java Basics - Anfänger-Themen 9
D Eine Stelle eines Char- Arrays nach dem vorkommen in einem ganzem anderem Array überprüfen Java Basics - Anfänger-Themen 20
S Abfrage Objekt-Array nach Datentypen Java Basics - Anfänger-Themen 6
B Array nach dem Alphabet sortieren Java Basics - Anfänger-Themen 11
K OOP Objektgefülltes Array nach minWert durchsuchen Java Basics - Anfänger-Themen 5
W Array nach Elemenden die durch 2 teilbar sind durchsehen Java Basics - Anfänger-Themen 9
F.S.WhiTeY Mehrdimensionales array, größere zahlen von innen nach außen Java Basics - Anfänger-Themen 3
C String array nach File array Java Basics - Anfänger-Themen 15
C Datentypen int[][]-Array nach String[][]-Array konvertieren Java Basics - Anfänger-Themen 7
Y Array initialisieren, nach der Abfrage? Java Basics - Anfänger-Themen 3
B String Array nach Int Array Java Basics - Anfänger-Themen 3
D Array nach ungerade zahlen sortieren Java Basics - Anfänger-Themen 6
N Integer Array der Größe nach ordnen Java Basics - Anfänger-Themen 1
S Inhalt von Array nach Zahl durchsuchen Java Basics - Anfänger-Themen 5
S array nach 2 kriterien sortieren Java Basics - Anfänger-Themen 3
T 2D Array nach gleichen Werten durchsuchen Java Basics - Anfänger-Themen 6
A array nach initialisierung final machen? Java Basics - Anfänger-Themen 17
F Casten: Object nach Array Java Basics - Anfänger-Themen 10
T Array verkleinern Java Basics - Anfänger-Themen 2
J Array aus Numberfield Eingaben Java Basics - Anfänger-Themen 7
D Array List mit Objekten sortieren Java Basics - Anfänger-Themen 2
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
Ü Zweidimensionales Array in der ersten Zeile deklarieren Java Basics - Anfänger-Themen 13
Thomas Uppe 2D Array Reihenfolge vermischen Java Basics - Anfänger-Themen 4
T array auslesen Java Basics - Anfänger-Themen 2
Nitrogames Variablen Variable aus JOptionPane Abfrage in Array einfügen Java Basics - Anfänger-Themen 4
moini Auf Array aus Superklasse zugreifen? Java Basics - Anfänger-Themen 2
J ArrayList in 2D-Array konvertieren. Java Basics - Anfänger-Themen 48
M NullPointerException: Cannot read the array length because "this.Kinder" is null Java Basics - Anfänger-Themen 1
P Wieso kann ich als Index für einen Array einen Char angeben? Java Basics - Anfänger-Themen 3
Finn_lol Fehlermeldung bei Schleife mit Array Java Basics - Anfänger-Themen 4
Proxy Chars vor array übergabe toLowerUpcase Java Basics - Anfänger-Themen 14
iAmFaiinez Primzahlen Tester ohne Array Java Basics - Anfänger-Themen 4
S array 2 dimensional treppe Java Basics - Anfänger-Themen 3
S Array 2x2 Blöcke mit 0 und 1 Java Basics - Anfänger-Themen 10
C Array von Klassen Java Basics - Anfänger-Themen 2
julian0507 2Dim-Array Spaltensummen Java Basics - Anfänger-Themen 1
XWing Doppelte Zahlen im Array Java Basics - Anfänger-Themen 8
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
W Items löschen aus String Array vom Custom Base Adapter Java Basics - Anfänger-Themen 2
Proxy Stack erweitern mit neuem Array falls der alte voll ist!? Java Basics - Anfänger-Themen 5
E Array, nächste Zahl zur 5 ausgeben, wie? Java Basics - Anfänger-Themen 42
J Array.list vergleichen Java Basics - Anfänger-Themen 1
W Java-Code mit Array Java Basics - Anfänger-Themen 14
D Reflections & Generisches Array Java Basics - Anfänger-Themen 4
T Array Java Basics - Anfänger-Themen 2
T Array Java Basics - Anfänger-Themen 15
T Wörteranzahl im Array zählen Java Basics - Anfänger-Themen 9
Ostkreuz Zweidimensionaler Array Index Java Basics - Anfänger-Themen 2
S String Array Buchstaben um einen gewissen Wert verschieben Java Basics - Anfänger-Themen 4
R Images aus einem Array ausgeben Java Basics - Anfänger-Themen 3
R 2d Array individuell machen Java Basics - Anfänger-Themen 4
D 2D Char Array into String Java Basics - Anfänger-Themen 2
J Array Median bestimmen Java Basics - Anfänger-Themen 6
S Array Maximum bestimmen mit for und foreach Java Basics - Anfänger-Themen 7
S Prüfen ob ein zweidimensionales Array rechteckig ist Java Basics - Anfänger-Themen 4
N Array Java Basics - Anfänger-Themen 1
J Array Mittleren Wert bestimmen Java Basics - Anfänger-Themen 2
D OOP Array einem Objekt zuweisen Java Basics - Anfänger-Themen 2
O Zahlen aus einem char-array per char + Zeichen addieren Java Basics - Anfänger-Themen 2
S leeres Array statt Null Pointer Exception ausgeben Java Basics - Anfänger-Themen 20
S Inhalte aus Array vergleichen und Max ausgeben Java Basics - Anfänger-Themen 3
M 2d array ohne längen anlegen Java Basics - Anfänger-Themen 4
S Bestimmte werte aus einem Array löschen Java Basics - Anfänger-Themen 2
S Ausgeben wie oft ein Wert in einem Array vorkommt Java Basics - Anfänger-Themen 7
E Reihenfolge der Werte umdrehen (mittels statischem int-Array Java Basics - Anfänger-Themen 3
O 2 Dimensionales Array Java Basics - Anfänger-Themen 6
M Bubble Sort - Int[] Array sortieren Java Basics - Anfänger-Themen 2
javaBoon86 Array mehrere Dimensionen Java Basics - Anfänger-Themen 10
B Explizit Array definieren geht nicht? Java Basics - Anfänger-Themen 14
D Kleinste Zahl in Array finden die vorher noch errechnet werden müssen. Java Basics - Anfänger-Themen 4
L Gegebenes Array sortieren, indem zufällige Zahlenpaare aus Array ausgewählt werden Java Basics - Anfänger-Themen 14
Say 2-DIM Array Code lesen und verstehen Java Basics - Anfänger-Themen 5
N Array beim erstellen mit Werten füllen Java Basics - Anfänger-Themen 6
C Java Array Struktur, welche ist wann besser? Java Basics - Anfänger-Themen 12
Temsky34 Array IndexOf nicht verfügbar Java Basics - Anfänger-Themen 18
belana wie am besten 2D Array von String to Integer Java Basics - Anfänger-Themen 18

Ähnliche Java Themen

Neue Themen


Oben