Moritz Neumeier c620449f0f LifeTest third step passed | 3 years ago | |
---|---|---|
.idea | 3 years ago | |
jars | 3 years ago | |
out | 3 years ago | |
src | 3 years ago | |
test | 3 years ago | |
.gitignore | 3 years ago | |
GameOfLifeAssignment.iml | 3 years ago | |
GameOfLifeTDD.iml | 3 years ago | |
README.md | 3 years ago |
Ihre Aufgabe ist es, eine Klasse Life
zu implementieren,
die das Game of Life simuliert. Beim Game of Life
werden Zellen in einem zweidimensionelen Raster angeordnet.
An jedem Rasterpunkt kann entweder eine lebende Zelle oder ein
Leerraum positioniert werden.
Für das Entstehen, Überleben oder Absterben einer Zelle ist die Anzahl der unmittelbaren Nachbarn entscheidend. Jeder Rasterpunkt hat 8 benachbarte Rasterpunkte (links, rechts, oben, unten, oben links, oben rechts, unten links, unten rechts). Für die Berechnung der nachfolgenden Generation sind auf die aktuelle Generation folgende Regeln anzuwenden:
Eine neue Zelle an einem bisher unbelebten Rasterpunkt entsteht, wenn genau drei benachbarte Rasterpunkte mit lebenden Zellen besetzt sind.
Lebende Zellen mit weniger als zwei lebenden Nachbarn sterben in der Folgegeneration an Einsamkeit.
Eine lebende Zelle mit zwei oder drei lebenden Nachbarn bleibt in der Folgegeneration am Leben.
Lebende Zellen mit mehr als drei lebenden Nachbarn sterben in der Folgegeneration an Überbevölkerung.
Im Assignment werden Ihnen drei Code-Dateien vorgegeben:
Life
soll später den Produktivcode enthalten.LifeTest
soll für den Testcode benutzt werden.ILife
ist ein Interface, das von der Life
-Klasse
implementiert werden soll.Implementieren Sie die Klasse Life
unter Nutzung der TDD-Vorgehensweise.
Erstellen Sie für die oben genannten Regeln jeweils mindestens einen Testfall (für
die erste Regel wurde bereits ein Testfall mitgeliefert).