Mit unserem Wissen über Schleifen und Verzweigungen können wir bereits aus einem einfachen Labyrinth finden.
Schreibe möglichst kompakten Code, der aus dem Labyrinth findet. Schau falls nötig bei Wiederholungen und Schleifen oder Verzweigungen nach, wie diese im Code umgesetzt werden.
Mögliche Lösung
while (!kara.mushroomFront()) {
if (kara.treeFront()) {
kara.turnRight();
} else {
kara.move();
}
}
Schwieriger wird es, wenn je nach Situation nach links statt nach rechts gewendet werden soll. Wie wird sich Kara mit dem Code von Aufgabe 6 bewegen? Findet Kara zum Pilz? Was musst du ändern, um ins Ziel zu kommen?
Mögliche Lösung
while (!kara.mushroomFront()) {
if (kara.treeFront()) {
kara.turnRight();
if (kara.treeFront()) {
// Umdrehen, wenn die Rechtsdrehung nichts gebracht hat.
kara.turnLeft();
kara.turnLeft();
}
} else {
kara.move();
}
}
Damit wir Kara nicht die ganze Zeit umdrehen müssen, können wir sie auch zusätzlich fragen, ob links oder rechts von ihr ein Baum ist:
Lösung
while (!kara.mushroomFront()) {
if (kara.treeFront()) {
if (kara.treeLeft()) {
kara.turnRight();
} else {
kara.turnLeft();
}
} else {
kara.move();
}
}
+
+
### Aufgabe 9
Reicht das bereits, um aus jedem Labyrinth hinauszufinden? Zu früh gefreut, hier wartet die nächste Herausforderung! Überlege dir zuerst, wie du aus einem Labyrinth finden würdest, bevor du dich an den Code wagst!
<HTML><script type="text/p5">
KaraWorld.create(
`TTTTTTTTT
T> T
TTTTTTT T
T T T
T T TT TT
T T T
T TTTTTTT
M T
TTTTTTTTT`);
</script></HTML>
++++Ideen
* … einfach mal die Hand an die Wand legen und nie loslassen!
++++Lösung
while (!kara.mushroomFront()) {
// Wir folgen der rechten Wand
if (!kara.treeRight()) {
kara.turnRight();
kara.move();
} else if (!kara.treeFront()) {
kara.move();
} else {
kara.turnLeft();
}
}
### Wie weiter?
Gratulation, du hast das Kara-Labyrinth Dossier fertig bearbeitet!
Aber halt! Gibt es Labyrinthe, aus denen wir mit dem Wand-Folge-Algorithmus nicht hinausfinden? Was könnte man in dieser Situation tun?
++++Ideen
* Wenn Kara mitten im Raum steht, müssen wir zuerst eine Wand findent!
* Wenn die gefolgte Wand eine Insel im Labyrinth bildet, so laufen wir im Kreis.
* Abhilfe:
* Wir könnten uns merken, wo wir bereits durchgelaufen sind, und allenfalls eine andere Abzweigung nehmen ([[wpde>Ariadnefaden]]).
* Wir könnten Kara auch einfach eine Zufallswahl treffen lassen und hoffen, dass wir irgendwann zum Pilz finden...
* Mehr Ideen: [[wpde>Lösungsalgorithmen_für_Irrgärten]]
++