## Labyrinthe Mit unserem Wissen über Schleifen und Verzweigungen können wir bereits aus einem einfachen Labyrinth finden. ### Aufgabe 6 Schreibe möglichst kompakten Code, der aus dem Labyrinth findet. Schau falls nötig bei [[phtg:fdif:karatutorial:loops]] oder [[phtg:fdif:karatutorial:verzweigungen]] nach, wie diese im Code umgesetzt werden. ++++Mögliche Lösung| while (!kara.mushroomFront()) { if (kara.treeFront()) { kara.turnRight(); } else { kara.move(); } } ++++ ### Aufgabe 7 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? Denk dran, dass sich Verzweigungen (`if`) und Schleifen (`while`) beliebig ineinander verschachteln lassen! ++++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(); } } ++++ ### Mehr Bedingungen 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: * `kara.treeLeft()` trifft zu, falls links von Kara (in Laufrichtung) ein Baum steht. * `kara.treeRight()` trifft zu, falls links von Kara (in Laufrichtung) ein Baum steht. ### Aufgabe 8 Schreibe die Lösung zu Aufgabe 7 um, indem du die neuen Bedingungen einbaust! ++++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! ++++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]] ++++ ### Aufgabe 10 (Challenge) Finde aus dem untenstehenden Labyrinth! ++++Lösung| // Wand suchen while (!kara.treeFront()) { kara.move(); ; } kara.turnLeft() // Folge der rechten Wand while (!kara.mushroomFront()) { if (!kara.treeRight()) { kara.turnRight(); kara.move(); } else if (!kara.treeFront()) { kara.move(); } else { kara.turnLeft(); } } ++++