Table of Contents

Klassen Laby und Zelle

Klassen

Klassen sind Teil eines verbreiteten und sehr nützlichen Programmierkonzepts.

Für unsere Zwecke sind Klassen eine Zusammenfassung von Daten (Variablen, genannt Attribute) und Funktionen (gennant Methoden), die mit diesen Attributen interagieren.

Diese Einheit erlaubt es sicherzustellen, dass die Daten immer konsistent sind.

Z.B. im Falle unseres Labyrinths stellen die Klassen sicher, dass wenn die Mauer von einer Zelle zur anderen geöffnet wird, dass das auch automatisch in umgekehrter Richtung geschieht.

Einrichten

Legen Sie einen neuen Ordner an und speichern Sie die beiden folgenden Dateien im neuen Ordner (Rechtslick → Ziel speichern unter oder so ähnlich):

laby.py zelle.py

Hello Laby

Öffnen Sie den neuen Ordner, der die beiden Dateien laby.py und zelle.py enthält und legen Sie dort eine neue Datei hello.py an.

hello.py
from laby import Laby
from zelle import Zelle
 
l = Laby(5,3)
print(l)

Zellen markieren

l[2,1].mark = 'Z'
print(l)
print(f"Zelle (2,1) ist mit {l[2,1].mark} markiert")

Mauern öffnen/schliessen

Der erste Parameter gibt die Richtung an, in welche die Mauer geöffnet werden soll (0 rechts, 1 unten, 2 links, 3 oben).

l[1,1].oeffneMauer(0)
l[2,1].oeffneMauer(1)

Ist der zweite, optionale Parameter False, wird die Mauer geschlossen:

l[2,1].oeffneMauer(1, False)

Aufgaben

Die Aufgaben (ohne Zusatzaufgaben) sollten von allen gelöst werden.

Die Zusatzaufgaben sind dazu da, damit sich jene mit mehr Übung nicht langweilen ;-)

Kreuz

Programmieren Sie in Labyrinth das wie folgt aussieht:

+---+---+---+---+---+
|   |   |   |   |   |
+---+---+   +---+---+
|   |   |   |   |   |
+---+---+   +---+---+
|                   |
+---+---+   +---+---+
|   |   |   |   |   |
+---+---+   +---+---+
|   |   |   |   |   |
+---+---+---+---+---+

Zusatzaufgabe: Schreiben Sie ein Programm so, dass es für alle Labyrinthgrössen funktioniert. Hinweise:

breite = l.breite  # Anzahl Zellen horizontal
hoehe = l.hoehe    # Anzahl Zellen vertikal
 
print(7//2)  # Ganzzahldivision, wird immer abgerundet, ergibt also 3 (und nicht 3.5)

Heizkörper

Produzieren Sie folgendes Labyrinth:

+---+---+---+---+---+---+---+---+
|                               |
+---+---+---+---+---+---+---+   +
|                               |
+   +---+---+---+---+---+---+---+
|                               |
+---+---+---+---+---+---+---+   +
|                               |
+   +---+---+---+---+---+---+---+
|                               |
+---+---+---+---+---+---+---+---+

Hinweis:

Zusatzaufgabe: Programm funktioniert für beliebige Labyrinthgrössen.

Text

Programmieren Sie folgende Ausgabe:

+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+
|   |   |   | P | r | o | g | r | a | m | m | i | e | r | e | n |   |   |   |   |
+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+
|   |   |   |   |   |   |   | m | a | c | h | t |   |   |   |   |   |   |   |   |
+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+
|   |   |   |   |   |   |   | S | p | a | s | s |   |   |   |   |   |   |   |   |
+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+

Hinweis: mit for buchstabe in “blabla”: kann etwas für jeden Buchstaben wiederholt werden.

Zusatzaufgabe: Das Programm funktioniert mit beliebigen Texten als einzige Vorgabe

# Vorgegebener Text
text = "Das geht auch voll automatisiert"
 
# Der Rest ist automatisch
woerter = text.split(" ")     # Text nach Leerschlägen aufteilen und als Liste speichern.
anzahlWoerter = len(woerter)  # Anzahl Wörter
 
lmax = max([len(w) for w in woerter])   # Anzahl Buchstaben im längsten Wort
 
# ...
 
for index, wort in enumerate(woerter):  # Wiederhole für jedes Wort, inkl. index
   pass  # Tu erst mal nix