Benutzer-Werkzeuge

Webseiten-Werkzeuge


neuerlehrplan:klasse10:schleifen

Schleifen

Die Beispiele aus diesem Abschnitt können in einem Jupyternotebook nachvollzogen werden. Es muss zusammen mit den Bilddateien vorher entpackt werden.

Danach kann man das Notebook zusammen mit den Bildern z.B. bei https://jupyter.org/try → JupyterLab hochladen und öffnen.

Häufig wiederholen sich Anweisungen in Algorithmen. Solche Anweisungen lassen sich in der Datenstruktur Schleife zusammenfassen. Die Frage ist nun, wie oft die Anweisungen wiederholt werden sollen. Auf diese Frage gibt es mehrere Antworten:

Schleifen mit Abbruchbedingung

Kopfgesteuerte Schleife

Wiederhole solange die Bedingung erfüllt ist:
…Anweisungen…

Bei der kopfgesteuerten Schleife wird die Schleifenbedingung am Anfang der Schleife getestet. Die Schleife wird immer wieder durchlaufen, solange die Bedingung erfüllt ist. Wenn die Bedingung beim Eintritt nicht erfüllt, wird die Schleife nicht durchlaufen.

Struktogramm

Fußgesteuerte Schleife

Wiederhole:
…Anweisungen…
solange die Bedingung erfüllt ist

Bei der fußgesteuerten Schleife wird die Schleifenbedingung am Ende der Schleife getestet. Die Schleife wird immer wieder durchlaufen, solange die Bedingung erfüllt ist. Wenn die Bedingung beim Eintritt nicht erfüllt, wird die Schleife mindestens einmal durchlaufen.

Struktogramm

Schleifen mit Abbruchbedingung in Python

In Python wird eine kopfgesteuerte Schleife mit der while-Anweisung umgesetzt. Für fußgesteuerte Schleifen gibt es keine eigene Anweisung, es gibt aber mehrere Möglichkeiten, eine fußgesteuerte Schleife zu simmulieren. Widmen wir uns aber zunächst der while-Anweisung und ihrer Syntax:

while Bedingung:
    ... Anweisungen ... 

Nach while steht die Bedingung, gefolgt von einem Doppelpunkt. Solange die Bedingung erfüllt ist, wird die Schleife durchlaufen. Wir müssen also in der Schleife dafür sorgen, dass die Bedingung irgendwann nicht erfüllt ist, sonst haben wir eine Endlosschleife.

Beispiel 1

Erstelle ein Programm, welches nach Eingabe einer ganzen Zahl die Quadratzahl berechnet. Nach jeder Berechnung soll gefragt werden ob das Programm fortgesetzt erden soll. Bei Eingabe von „Nein“ wird das Programm beendet.

# Die Variable eingabe muss initialisiert werden, sonst kommt es beim Eintritt in die Schleife zur Fehlermeldung
eingabe = ""
while eingabe != "N":
    zahl = int(input("Zahl: "))
    print("Quadratzahl:",zahl*zahl)
    eingabe = input("Soll das Programm fortgesetzt werden? (J|N)")

Schleife mit Zähler

m Unterschied zu fuß- und kopfgesteuerten Schleifen steht bei Zählschleifen die Anzahl der Durchläufe vor dem Schleifeneintritt fest. Dabei nimmt eine sogenannte Zählvariable während des Schleifendurchlaufs eine endliche Anzahl von fest definierten Werten an.

In verbaler Kurzform lässt sich der Algorithmus wie folgt formulieren:

Für Startwert bis Endwert mit Schrittweite führe aus: …Anweisungen…

Struktogramm

Zählschleifen in Python

In Python kann man eine Zählschleife mit Hilfe der for- und der range-Anweisung umsetzen. Die range-Anweisung erzeugt dabei die Werte, die die Zählvariable durchlaufen soll. Sie besitzt den folgenden Aufbau:

range (Startwert, Endwert, Schrittweite) 

Startwert und Schrittweite können weggelassen werden. Es wird dann angenommen, dass der Startwert den Wert 0 hat und die Schrittweite den Wert 1 hat. Fehlt nur ein Parameter, so wird angenommen, dass die Schrittweite fehlt. range erzeugt nun eine Folge von Werten, die mit dem Startwert beginnt. Der jeweils nächste Wert ergibt sich, indem man zu einem Wert die Schrittweite addiert. Das wird wird immer weiter fortgesetzt, solange ein Wert noch keiner ist als der Endwert.

Hier einige Beispiele. In den Beispielen wird die Ausgabe von range in eine Liste umgewandelt. Zu Listen erfährst du weiter unten mehr.

print(list(range(1,9,3)))
print(list(range(1,10)))
print(list(range(8)))

Ausgabe des Programms:

[1, 4, 7]
[1, 2, 3, 4, 5, 6, 7, 8, 9]
[0, 1, 2, 3, 4, 5, 6, 7]

Im Zusammenhang mit einer sogenannten for-Schleife benutzt man range nun wie folgt:

for i in range(Startwert, Endwert, Schrittweite):
    ... Anweisungen ... 

Die Variable i nimmt nun bei jeden Schleifendurchlauf einen von range erzeugten Wert an. Man kann nun i mit dem jeweiligen Wert in der Schleife benutzen oder man benutzt das Konstrukt einfach, um die Anzahl der Durchläufe festzulegen.

Beispiel 2

Schreibe ein Programm, welches eine Liste der Quadratzahlen bis 20 ausgibt.

Struktogramm

Lösung

# Beispiel 2
print("Zahl","Quadratzahl")
for i in range(1,21):
    print(i,"\t",i*i)

Die for-Anweisung und Listen

Bereits weiter oben habe ich den Datentyp Liste erwähnt. Listen gehören in Python zu den zusammengesetzten Datentypen. Eine Liste kann man sich als einen Behälter für mehrere Werte vorstellen. Diese Werte können unterschiedliche Datentypen haben Sie können sogar selbst wieder Listen sein. Listen erkennt man in Python durch eckige Klammern. In den Klammern werden die Werte durch ein Komma getrennt.

Beispiel 3

[1,23,7,4]
["Hallo",4,34.2,True]

In der ersten Liste sind nur ganze Zahlen als Werte enthalten. In der zweiten Liste stehen Werte unterschiedlicher Datentypen.

Eine Liste kann man mit dem Zuweisungsoperator = erzeugen.

Beispiel 4

liste1 = [1,23,7,4]
liste2=["Glauchau","Meerane","Waldenburg", "Mülsen", "Thurm"]
liste3=[[1,2,3],[4,5,6],[7,8,9]]
liste4=[] #leere Liste

Auch das Anlegen einer leeren Liste kann sinnvoll sein, wenn man durch Anhängen von weiteren Listenelementen eine Liste aufbauen will.

Beispiel 5

Wir betrachten die Liste

liste1=[1,23,21,23,12]

Die gesamte Liste lässt sich mit Hilfe der print-Anweisung ausgeben:

print(liste1)

Ausgabe:

[1, 23, 21, 23, 12]

Auf einzelne Listenelemente kann man durch Angabe der Nummer (den Index) des Listenelements zugreifen. Die Nummer steht dabei nach dem Listennamen in eckigen Klammern. Die Zählung beginnt bei 0.

print(liste1[2])

Ausgabe:

21

Listen sind in Python ein sogenannte abzählbarer (itterierbarer) Datentyp. Neben Listen gibt es in Python noch weitere solche Datentypen (z.B. Tupel). Mit der for-Anweisung kann man nun ohne die Verwendung von range eine Schleife über alle Elemente eines solchen Datentyps laufen lassen.

Beispiel 6

liste = [3, 5.5, "Python ist cool!", False]
for wert in liste:
    print(wert)

Endlosschleifen

Wenn ich im Schleifenkopf schreibe

while True:
    ... Anweisungen ... 

ist die Schleifenbedingung immer erfüllt und die Schleife endet nie. Es entsteht eine Endlosschleife. Diese widerspricht eigentlich der Algorithmeneigenschaft Endlichkeit.

Es gibt aber Möglichkeiten, wie man eine solche Schleife anders beenden kann:

  • Die Anweisung break beendet eine Schleife.
  • Die Anweisung continue beendet den aktuellen Schleifendurchlauf und beginnt mit dem nächsten.

Beispiel 7

while True:
    zahl = int(input("Zahl: "))
    print("Quadratzahl:",zahl*zahl)
    eingabe = input("Soll das Programm fortgesetzt werden? (J|N)")
    if eingabe == 'N':
        break

Übungen

Im folgenden Jupyternotebook finden sich einige Übungsaufgaben zum Thema.

neuerlehrplan/klasse10/schleifen.txt · Zuletzt geändert: von lutz