Logo des digitalen Schulbuchs inf-schule.de. Schriftzug in Zustandsübergangsdiagramm eines endlichen Automaten.

Fachkonzept - Fallunterscheidung

Alternative Abläufe

Häufig kommt es vor, dass man bei der Verabeitung von Daten unterschiedliche Wege gehen muss.

Flussdiagramm - Münzwurf

Solche alternativen Abläufe lassen sich sehr gut mit Flussdiagrammen verdeutlichen.

Fachkonzept - Fallunterscheidungen

Bei der Modellierung alternativer Abläufe verwendet man meist zwei Ablaufmuster, die man als zweiseitige Fallunterscheidung bzw. einseitige Fallunterscheidung bezeichnet. Diese Fallunterscheidungsvarianten sollen jetzt genauer betrachtet werden.

Eine zweiseitige Fallunterscheidung besteht aus einer Bedingung und zwei Anweisungssequenzen, einer für den Fall, dass die Bedingung erfüllt ist, und einer für den anderen Fall.

Die Struktur einer solchen zweiseitigen Fallunterscheidung beschreibt man oft mit einem Struktogramm:

Struktogramm - zweiseitige Fallunterscheidung

Das folgenden Flussdiagramm vereutlicht die Ausführung einer solchen zweiseitigen Fallunterscheidung.

Programmablaufplan - zweiseitige Fallunterscheidung

Bei der Ausführung einer zweiseitigen Fallunterscheidung wird zunächst überprüft, ob die Bedingung erfüllt ist. Ist das der Fall, so werden die Anweisungen der entsprechenden Anweisungssequenz ausgeführt. Andernfalls werden die Anweisungen der anderen Anweisungssequenz ausgeführt.

Eine einseitige Fallunterscheidung besteht aus einer Bedingung und nur einer Anweisungssequenz.

Das Struktogramm zu dieser Fallunterscheidungsvariante sieht so aus:

Struktogramm - einseitige Fallunterscheidung

Hier das entsprechende Flussdiagrammen zur Beschreibung der Ausführung:

Programmablaufplan - einseitige Fallunterscheidung

Bei der Ausführung einer einseitigen Fallunterscheidung wird zunächst überprüft, ob die Bedingung erfüllt ist. Ist das der Fall, so werden die Anweisungen der Anweisungssequenz ausgeführt. Andernfalls geschieht gar nichts.

Implementierung von Fallunterscheidungen in Python

Fallunterscheidungen werden in Python mit if-Anweisungen dargestellt.

In der zweiseitigen Variante ist eine if-Anweisung wie folgt aufgebaut:

if [Bedingung]:
    [Anweisungssequenz]
else:
    [Anweisungssequenz]

Beispiel:

if zahl == 0:
    print('Kopf ist gefallen.')
    seite = 'K'
else:
    print('Zahl ist gefallen.')
    seite = 'Z'

Eingeleitet wird sie mit dem Schlüsselwort if. Anschließend folgt eine Bedingung, die einfach oder auch zusammengesetzt sein kann. Wichtig ist der Doppelpunkt nach der Bedingung. Dieser Doppelpunkt deutet darauf hin, dass jetzt die Anweisungen folgen, die ausgeführt werden sollen, wenn die Bedingung erfüllt ist. Nach dem (uneingerückten) Schlüsselwort else und einem Doppelpunkt folgen - wieder eingerückt - die Anweisungen, die ausgeführt werden sollen, wenn die Bedingung nicht erfüllt ist.

In der einseitigen Variante fehlt der gesamte else-Teil:

if [Bedingung]:
    [Anweisungssequenz]

Beispiel:

if tipp == 'k':
    tipp = 'K'
if tipp == 'z':
    tipp = 'Z'

Fallunterscheidungen kann man schachteln, wie das folgende Beispiel zeigt:

from random import randint
# Verarbeitung
augen = randint(1, 6)
if augen == 1:
    bild = 'o'
else:
    if augen == 2:
        bild = 'oo'
    else:
        if augen == 3:
            bild = 'ooo'
        else:
            # ...
# Ausgabe
print(bild)

Wenn auf diese Weise sehr viele Fälle getrennt betrachtet werden sollen, dann kann man die Fallunterscheidung in Python auch übersichtlicher wie folgt implementieren:

from random import randint
# Verarbeitung
augen = randint(1, 6)
if augen == 1:
    bild = 'o'
elif augen == 2:
    bild = 'oo'
elif augen == 3:
    bild = 'ooo'
elif augen == 4:
    bild = 'oooo'
elif augen == 5:
    bild = 'ooooo'
else:
    bild = 'oooooo'
# Ausgabe
print(bild)

Das Schlüsselwort elif steht hier abkürzend für else if .

Verallgemeinerd lässt sich diese if-Variante wie folgt darstellen:

if [Bedingung]:
    [Anweisungssequenz]
elif [Bedingung]:
    [Anweisungssequenz]
elif [Bedingung]:
    [Anweisungssequenz]
...
else:
    [Anweisungssequenz]

Der abschließende else-Block kann auch fehlen.

X

Fehler melden

X

Suche