Lernpfad:Rekursion in Java/Rekursion bei Schachproblemen: Unterschied zwischen den Versionen
Zur Navigation springen
Zur Suche springen
Thi (Diskussion | Beiträge) Keine Bearbeitungszusammenfassung |
Thi (Diskussion | Beiträge) Keine Bearbeitungszusammenfassung |
||
Zeile 1: | Zeile 1: | ||
Im Kontext des Schachspiels gibt es zwei sehr bekannte Problemstellungen. | Im Kontext des Schachspiels gibt es zwei sehr bekannte Problemstellungen. | ||
An dieser Stelle sollen einfach nur ein paar Links für interessierte hinzugefügt werden: | An dieser Stelle sollen einfach nur ein paar Links für interessierte hinzugefügt werden: | ||
== Dameproblem == | |||
https://de.wikipedia.org/wiki/Damenproblem | |||
Man versucht 8 Damen auf dem Schachbrett zu positionieren. Dabei müssen die Damen so aufgestellt werden, | Man versucht 8 Damen auf dem Schachbrett zu positionieren. Dabei müssen die Damen so aufgestellt werden, | ||
dass sich keine Damen gegenseitig schlagen. | dass sich keine Damen gegenseitig schlagen. | ||
Zeile 33: | Zeile 35: | ||
</p5js> | </p5js> | ||
== Springerproblem == | |||
## https://de.wikipedia.org/wiki/Springerproblem | ## https://de.wikipedia.org/wiki/Springerproblem | ||
## http://www.axel-conrad.de/springer/springer.html | ## http://www.axel-conrad.de/springer/springer.html |
Version vom 8. Januar 2019, 23:11 Uhr
Im Kontext des Schachspiels gibt es zwei sehr bekannte Problemstellungen. An dieser Stelle sollen einfach nur ein paar Links für interessierte hinzugefügt werden:
Dameproblem
https://de.wikipedia.org/wiki/Damenproblem Man versucht 8 Damen auf dem Schachbrett zu positionieren. Dabei müssen die Damen so aufgestellt werden, dass sich keine Damen gegenseitig schlagen.
Arbeitsauftrag
Versuche auf einem 5x5 Feld 5 Damen aufzustellen.
Lösung:
Ein rekursiver Algorithmus könnte wie folgt aussehen:
dame(t)
Falls t < 8 ist DANN
Wiederhole für alle Positionen (starte bei 0)
aktuelle Reihe gleich nächste Position
Falls die aktuelle Reihe noch frei ist DANN
setze die Dame auf die freie Reihe
Falls die Dame mit keiner anderen kollidiert DANN
dame(t+1)
Entferne die aktuelle Dame aus der Reihe
SONST
speicher die Lösung