Unterschiede

Hier werden die Unterschiede zwischen zwei Versionen der Seite angezeigt.

Link zu der Vergleichsansicht

Nächste Überarbeitung
Vorherige Überarbeitung
phtg:fdif:karatutorial:labyrinthe2 [2024-10-31 10:03] – angelegt hofphtg:fdif:karatutorial:labyrinthe2 [2024-11-01 09:18] (aktuell) hof
Zeile 1: Zeile 1:
-## Labyrinthe +## Labyrinth - Test
-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.+
  
 <HTML> <HTML>
Zeile 10: Zeile 6:
  
 <HTML><script type="text/p5"> <HTML><script type="text/p5">
-KaraWorld.create( 
-  `TTTTTTTTT 
-   T>      T 
-   TTTTTTT T 
-       T T 
-   TTT TTT T 
-         M 
-   T TTTT  T 
-         T 
-   TTTTTTTTT`); 
-</script></HTML> 
- 
-++++Mögliche Lösung| 
-<code javascript> 
 while (!kara.mushroomFront()) { while (!kara.mushroomFront()) {
-    if (kara.treeFront()) { +   if (kara.treeFront()) { 
-        kara.turnRight(); +       kara.turnLeft(); 
-    } else { +       if (kara.treeFront()) { 
-        kara.move(); +           kara.turnLeft(); 
-    }+           kara.turnLeft(); 
 +       } 
 +   } else { 
 +       kara.move(); 
 +       kara.turnLeft(); 
 +       if (kara.treeFront()) { 
 +           kara.turnRight(); 
 +           kara.turnRight(); 
 +           if (kara.treeFront()) { 
 +               kara.turnLeft(); 
 +           } 
 +       } 
 +   }
 } }
-</code> +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! 
- 
-<HTML><script type="text/p5"> 
-// Lösung von Aufgabe 6 - was passiert? 
-while (!kara.mushroomFront()) { 
-    if (kara.treeFront()) { 
-        kara.turnRight(); 
-    } else { 
-        kara.move(); 
-    } 
-} 
 KaraWorld.create( KaraWorld.create(
   `TTTTTTTTT   `TTTTTTTTT
-   T     T +        <
-   TTTTTTT T+   TT TTTTTT
          T          T
-   T TTTTTTT +   TTTTTTMTT`);
-         T +
-   TTTTTTT T +
-         T +
-   TTTTTTTTT`);+
 </script></HTML> </script></HTML>
  
-++++Mögliche Lösung| +### Erstes Laby
-<code javascript> +
-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(); +
-    } +
-+
-</code> +
-++++ +
-### 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 +<HTML><script type="text/p5">
-Schreibe die Lösung zu Aufgabe 7 um, indem du die neuen Bedingungen einbaust! +
- +
-++++Lösung| +
-<code javascript>+
 while (!kara.mushroomFront()) { while (!kara.mushroomFront()) {
-    if (kara.treeFront()) { +   if (kara.treeFront()) { 
-        if (kara.treeLeft()) { +       kara.turnLeft(); 
-            kara.turnRight(); +       if (kara.treeFront()) { 
-        } else { +           kara.turnLeft(); 
-            kara.turnLeft(); +           kara.turnLeft(); 
-        +       
-    } else { +   } else { 
-        kara.move(); +       kara.move(); 
-    }+       kara.turnLeft(); 
 +       if (kara.treeFront()) { 
 +           kara.turnRight(); 
 +           kara.turnRight(); 
 +           if (kara.treeFront()) { 
 +               kara.turnLeft(); 
 +           } 
 +       } 
 +   }
 } }
-</code> +kara.move()
-+++++
  
-### Aufgabe 9 +KaraWorld.fromOptions
-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! +  `TTT TTTTT
- +
-<HTML><script type="text/p5"> +
-KaraWorld.create+
-  `TTTTTTTTT +
-   T>      T +
-   TTTTTTT T+
        T        T
-   T T TT TT +   T T T TTT 
-   T T     +   T T T   
-   TTTTTTT +   TTT T T 
-   M       +   T T  <T 
-   TTTTTTTTT`);+   T   TT 
 +   TTTTTT TT`, { 
 +      keyhandler: false, 
 +      delay_ms: 100, 
 +      max_commands: 300, 
 +    });
 </script></HTML> </script></HTML>
  
-++++Ideen| 
-  * ... einfach mal die Hand an die Wand legen und nie loslassen! 
-++++ 
  
-++++Lösung| +### Grösseres Laby
-<code javascript> +
-while (!kara.mushroomFront()) { +
-    // Wir folgen der rechten Wand +
-    if (!kara.treeRight()) { +
-        kara.turnRight(); +
-        kara.move(); +
-    } else if (!kara.treeFront()) { +
-        kara.move(); +
-    } else { +
-        kara.turnLeft(); +
-    } +
-+
-</code> +
-++++ +
-### 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! 
  
 <HTML> <HTML>
 <script type="text/p5" data-preview-width="600" data-height="600"> <script type="text/p5" data-preview-width="600" data-height="600">
 +while (!kara.mushroomFront()) {
 +   if (kara.treeFront()) {
 +       kara.turnLeft();
 +       if (kara.treeFront()) {
 +           kara.turnLeft();
 +           kara.turnLeft();
 +       }
 +   } else {
 +       kara.move();
 +       kara.turnLeft();
 +       if (kara.treeFront()) {
 +           kara.turnRight();
 +           kara.turnRight();
 +           if (kara.treeFront()) {
 +               kara.turnLeft();
 +           }
 +       }
 +   }
 +}
 +kara.move()
 +
 let game = KaraWorld.create( let game = KaraWorld.create(
     `TTTTTTTTTTTTTTTTTT     `TTTTTTTTTTTTTTTTTT
-                    T 
-          >         T 
                     T                     T
      TTT TTTTTTTTTTTTTT      TTT TTTTTTTTTTTTTT
-                    T+                >   T
      TTTTTTTT TTTTTTTTT      TTTTTTTT TTTTTTTTT
                   T T                   T T
Zeile 185: Zeile 132:
 </HTML> </HTML>
  
-++++Lösung| 
-<code javascript> 
-// 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(); +
-    } +
-+
-</code> +
-+++++
  • phtg/fdif/karatutorial/labyrinthe2.1730369031.txt.gz
  • Zuletzt geändert: 2024-10-31 10:03
  • von hof