Montag, 18. März 2013
Rekursionen (POS1: 2BHIF)
Implementieren Sie in einem Paket recursion
Klassen mit Testmethoden für folgende Aufgabenstellungen:
- Fakultät: 0! = 1, 1! = 1, n! = n * (n -1)
- Fibonaccizahlen: fib(0) = 0, fib(1) = 1, fib(n) = fib(n - 1) + fib(n - 2)
- McCarthys 91: f(n) = n-10, wenn n > 100 bzw. f(f(n+11)) für allen anderen n.
- Bestimmen Sie ob eine Zahl gerade oder ungerade ist, in dem Sie zwei indierekt rekursive Funkionen
boolean istUngerade(int n)
undboolean istGerade(int n)
verwenden. - Implementieren Sie den Euklidischen Algorithmus zum Finden des größten gemeinsamen Teilers zweier Zahlen.
Floodfill
Aus Wikipedia: Floodfill bzw. Flutfüllung ist ein Begriff aus der Computergrafik. Es ist ein einfacher Algorithmus, um Flächen zusammenhängender Pixel einer Farbe in einem digitalen Bild zu erfassen und mit einer neuen Farbe zu füllen.
Ausgehend von einem Pixel innerhalb der Fläche werden jeweils dessen Nachbarpixel darauf getestet, ob diese Nachbarpixel auch die alte Farbe enthalten. Jedes gefundene Pixel mit der alten Farbe wird dabei sofort durch die neue Farbe ersetzt.
Zwei Varianten des Algorithmus sind gängig:
- Es werden jeweils die vier benachbarten Pixel oben, unten, links und rechts vom Ausgangspunkt untersucht.
- Es werden jeweils die acht benachbarten Pixel oben, unten, links, rechts, oben-links, oben-rechts, unten-links und unten-rechts vom Ausgangspunkt untersucht.
Legen Sie ein neues Package floodfill
an und Erstellen Sie die beiden Klassen Grafik
und Logik mit dem unten angegebenen Source-Code (Dank an W. Schermann).
- floodfill.Grafik.java (enthält die Grafik-Funktionen und
main()
) - floodfill.Logik.java (enthält die Logik, sie müssen die Methode
run()
erweitern)
Speichern Sie die folgenden beiden Bilder in einem Ordner images
im Ordner des Projektes.
Implementieren Sie in der Logik
eine rekursive Funktion zum Füllen eines Bildabschnittes (In 4 Richtungen und alternativ in 8 Richtungen). Rufen Sie die rekursive Funktion aus der Funktion run
aus auf. Sie können folgende Funktionen der Grafik
-Klasse verwenden.
public Color getColor(int x, int y) //Bildfarbe abfragen public void setColor(int x, int y, Color c) //Bildfarbe ändern
Der Algorithmus ist hoch-rekursiv. Daher besteht ein hohes Risiko, dass der Algorithmus zu einem Stack-Überlauf führt. (Z.B. beim Hintergrund)
Um die Übung ohne trotzdem komplett testen zu können kann die Stack-Größe in Java verändert werden. In Eclipse kann dies bei den Argumenten der Virtual-Machine in den Run-Konfigurationen eingestellt werden. Mit -Xss5M
wird der Stack-Speicher auf 5 Megabyte gesetzt.
Beachten Sie die eventuellen "Fehler" beim Füllen mit dem Algorithmus für 8 benachbarte Pixel.
Abonnieren Posts [Atom]
Kommentar veröffentlichen