Programmieren Repetitionsdossier
Informationen
- Verwende nur die vordefinierten Funktionen, die im Dossier zur Programmierung vorkommen. Alles andere muss selbst programmiert werden. Soll man zum Beispiel die Summe aller Elemente einer Liste berechnen, so mache dies selbst in einer Schleife und verwende nicht die vordefinierte Funktion
sum()
. Diese Regel gilt auch für Prüfungen.
- Die Verwendung von repeat ist verboten! Verwende stattdessen while-Schleifen und später auch for-Schleifen.
- Es werden keine Musterlösungen verteilt. Sende deine Lösungen per Teams an deine Lehrperson, um eine Rückmeldung zu erhalten. Gib in einem Kommentar oberhalb der Aufgabe an, um welche Aufgabe es sich handelt, z.B.
# Aufgabe 1.7
. Gib weiter an, ob der Code funktioniert, resp. beschreibe den auftretenden Fehler.
- Die Aufgaben unten können durch weitere ergänzt werden, es lohnt sich also, regelmässig nachzuschauen.
1. Grundlagen I
benötigtes Vorwissen:
- Variablen
- while-Schleifen
- if-(elif-)else-Verzweigungen
1.1 Aufgabe
Bestimme die Summe aller dreistelliger ganzer Zahlen.
Das Resultat muss sein: $494550$
1.2 Aufgabe
1.3 Aufgabe
Pythagoras-Rechner: Die Idee ist, ein Programm zu schreiben, in welches man zwei Seiten von einem rechtwinkligen Dreieck eingeben kann und die dritte mithilfe des Satzes von Pythagoras dann berechnet wird.
Für den Satz vom Pythagoras gibt es zwei Fälle:
- Fall 1: Beide Katheten gegeben, berechne Hypotenuse
- Fall 2: Eine Kathete und Hypotenuse gegeben, berechne zweite Kathete
Zuerst soll die Benutzerin gefragt werden, welchen Fall (inkl. kurzer Beschreibung) sie berechnen möchte. Dann wird sie aufgefordert, die entsprechenden Werte für Kathete(n)/Hypotenuse einzugeben. Das Resultat wird berechnet und ausgegeben.
1.4 Aufgabe
1.5 Aufgabe
Der Benutzer wird aufgefordert, eine beliebige dreistellige Zahl einzugeben. Dem Benutzer wird zuerst einmal mitgeteilt ob er überhaupt eine Zahl eingegeben hat. Falls ja, wird weiter mitgeteilt, ob die eingegebene Zahl das Kriterium erfüllt.
Tipp: Mit type(x)
kann der Typ der Variable x
(z.B. int
oder str
) ermittelt werden.
1.6 Aufgabe
Bestimme das Produkt von allen Zahlen von 50 bis und mit 100.
Die Lösung ist 153425937812748301860136522976473486961422986084234447972389349349107947938617753600000000000000
.
1.7 Aufgabe
In der Mathematik (besonders in Wahrscheinlichkeit und Kombinatorik) braucht man oft die Fakultät: $$n! = n \cdot (n-1) \cdot (n-2) \cdot \ldots 2 \cdots 1$$ Einige Beispiele:
- Fakultät von $3$: $3! = 3 \cdot 2 \cdot 1 = 6$
- Fakultät von $5$: $5! = 5 \cdot 4 \cdot 3 \cdot 2 \cdot 1 = 120$
- Fakultät von $1$: $1! = 1$
- Fakultät von $0$ ist definiert als: $0! = 1$
- Fakultät von negativen Zahlen ist nicht definiert.
Der Benutzer wird aufgefordert eine Zahl einzugeben. Von dieser Zahl wird die Fakultät berechnet und ausgegeben. Stelle sicher, dass die Spezialfälle (0,1, negative Zahlen) auch korrekt verarbeitet werden.
1.8 Aufgabe
1.9 Aufgabe
- Der Benutzer wird aufgefordert, einen String einzugeben, der aus genau 10 Zeichen besteht. Dem Benutzer wird zurückgemeldet, ob der eingegebene String diese Bedingung erfüllt, ob er zu lange oder zu kurz ist. Die Länge eines Strings (z.B.
s = "Ich bin ein String"
) wird mitlen(s)
bestimmt.
- Modifiziere nun den Code so, dass der Benutzer solange aufgefordert wird, einen solchen String einzugeben, bis die Bedingung erfüllt ist.
1.10 Aufgabe
Lebenstipps: Die Benutzerin wird aufgefordert einzugeben, wie sie sich gerade fühlt auf einer Skala von $0$ (total mies) bis $5$ (sensationell!). Je nach eingegebener Zahl, soll ihr ein anderer Tipp fürs Leben mitgegeben werden.
1.11 Aufgabe
1.12 Aufgabe
Zeichne einen Kreis, ohne Funktionen wie rightArc(x,y)
, leftArc(x,y)
, leftCircle(x)
oder rightCircle(x)
zu verwenden. Verwende stattdessen forward(x)
und right(x)
usw.
2. Grundlagen II
benötigtes Vorwissen:
- Vorwissen von Grundlagen I
- Schleifen
- Funktionen
- Listen
2.1 Aufgabe
Löse nur, wenn du for-Schleifen kennst.
Wandle in while-Schleife um:
for i in range(4,12): print(i)
2.2 Aufgabe
Die Innenwinkelsumme in einem Dreieck ist 180 Grad. Sobald man also zwei Winkel kennt, kann man den dritten berechnen. Definiere eine Funktion innenwinkelsumme(a,b)
, welcher man zwei Winkel a und b übergibt. Die Funktion bestimmt dann den dritten Winkel und gibt diesen zurück.
2.3 Aufgabe
Schreibe eine Funktion mul(a,b)
, welche zwei ganze Zahlen a und b multipliziert und zurückgibt. Als einzige mathematische Operation darf Plus (+) verwendet werden! Die Operation * darfst du also nicht gebrauchen.
2.4 Aufgabe
Löse nur, wenn du for-Schleifen kennst.
Wandle in möglichst kurze for-Schleife (max. 2 Zeilen) um:
i = 10 while i < 29: print(i) i = i + 3
2.5 Aufgabe
Schreibe eine Funktion power(a,n)
, welche a hoch n berechnet und zurückgibt. Dabei darfst du den Hoch-Operator ** nicht gebrauchen:
- Variante 1 (einfacher): Verwende den Multiplikations-Operator *
- Variante 2 (anspruchsvoller): Verwende den Additions-Operator +
2.6 Aufgabe
Schreibe eine Funktion teilbar_durch(a,b)
, welche zwei ganze Zahlen als Argumente erwartet. Die Funktion gibt True (False) zurück, falls man a (nicht) durch b ohne Rest dividieren kann.
2.7 Aufgabe
Schreibe eine Funktion celsius_zu_fahrenheit(x)
, die eine Temperatur in Grad Celsius x in die entsprechende Temperatur in Fahrenheit umwandelt und zurück gibt. Die entsprechende Formel findest du hier: https://de.wikipedia.org/wiki/Grad_Fahrenheit#Umrechnung
2.8 Aufgabe
Schreibe eine Funktion div_mit_rest(a,b)
, welche zwei ganze Zahlen a und b ganzzahlig und mit Rest dividiert. Zurückgegeben wird eine Liste mit zwei Elementen: Das erste Element ist das Resultat der Division, das zweite der Rest. Als einzige mathematische Operationen darf Plus (+) und Minus (-) verwendet werden!
Für div_mit_rest(20,7)
erhält man die Liste [2,6] zurück, da 20:7 = 2 Rest 6 ist.
2.9 Aufgabe
Der Benutzer wird nach einer ganzen Zahl gefragt. Es wird dann eine Liste mit dieser Anzahl an Zufallszahlen gefüllt und ausgegeben.
2.10 Aufgabe
Löse nur, wenn du for-Schleifen kennst.
Schreibe als for-Schleife:
k = 4 while(k < 13): print(k) k = k+2
Schaffst du es mit nur zwei (oder gar einer) Zeile(n) Code?
2.11 Aufgabe
- Definiere eine Funktion
zweierpotenzen(n)
, welche die ersten n Zweierpotenzen in eine Liste schreibt und zurückgibt. Fürzweierpotenzen(5)
erhält man[2,4,8,16,32]
zurück.
- Erhöhter Schwierigkeitsgrad: Definiere nun eine zweite Version dieser Funktion
zweierpotenzen_b(n)
. Hier sollen nun diejenigen Zweierpotenzen in eine Liste geschrieben werden, die kleiner gleich n sind. Fürzweierpotenzen(20)
erhält man[2,4,8,16]
zurück.
2.12 Aufgabe
Definiere eine Funktion mittelwert(a, b, c, d)
, der vier Zahlen übergeben wird. Die Funktion soll deren Mittelwert berechnen und zurückgegeben. Übergibt man zum Beispiel vier Schulnoten, so erhält man den Notendurchschnitt zurück. Zeige den Durchschnittswert dann in einem formatierten String an, z.B. „Der Mittelwert ist 4.46“.
2.13 Aufgabe
Definiere eine Funktion mittelwert(L)
, welcher eine Liste mit Zahlen übergeben wird. Von diesen Zahlen wird dann der Mittelwert berechnet und zurückgegeben. Übergibt man zum Beispiel eine Liste mit Schulnoten, so erhält man den Notendurchschnitt zurück. Zeige den Durchschnittswert dann in einem formatierten String an, z.B. „Der Mittelwert ist 4.46“.
2.14 Aufgabe
Definiere eine Funktion anzahl_null(L)
, welcher eine Liste mit Zahlen übergeben wird. Es wird gezählt, wie oft der Wert 0 darin vorkommt. Diese Anzahl wird zurückgegeben. Für die List [5,0,4,1,2,0,3,0]
erhält man 3 zurück.
2.15 Aufgabe
Schreibe eine Funktion my_max(x,y,z)
, die von den drei Zahlen, die übergeben werden, die grösste bestimmt und zurückgibt. Verwende keine vordefinierten Funktionen, programmiere selbst.
2.16 Aufgabe
Einkaufs-Rechner
Du kaufst ein: 6 Eier (je 85 Rp.), 4 Brötchen (je 1.20 Fr.), 1 Flasche Rivella (2.50). Diese Information wird in zwei Listen gespeichert:
anzahl = [6,4,1] preise = [0.85,1.20,2.50]
Schreibe eine Funktion shopping_calculator(anz,pri)
die berechnet, wieviel der Einkauf kostet. Dieser Wert wird zurückgegeben. Für das obige Beispiel, also mit shopping_calculator([6,4,1],[0.85,1.20,2.50])
, soll man das Ergebnis $12.40$ erhalten.
2.17 Aufgabe
Schreibe eine Funktion fortune_cookie()
, die ein Glückskeks-Spruch-Generator ist: Jedesmal wenn die Funktion aufgerufen wird, wird random ein Spruch, der in einer Liste gespeichert wird, ausgegeben. Im Internet gibt es viele Sprüche, die du dafür verwenden kannst: https://examples.yourdictionary.com/articles/funny-fortune-cookie-sayings.html
2.18 Aufgabe
Schreibe eine Funktion find_42(L)
die zählt, wie oft die Zahl $42$ in der Liste L vorkommt und diese Anzahl zurückgibt. Verwende keine vordefinierten Funktionen.
2.19 Aufgabe
Schreibe eine Funktion split_list(L,x)
. Diese nimmt eine Liste mit Zahlen, sowie eine einzelne Zahl x entgegen. Die Zahlen in L sollen auf zwei Listen aufgeteilt werden: Die eine Liste soll alle Zahlen aus L, die kleiner gleich x sind beinhalten und die andere Liste alle Zahlen, die grösser sind. Die beiden Listen werden zurückgegeben.
2.20 Aufgabe
Weitere Umwandlungsaufgaben:
(zählen alle zusammen als eine Aufgabe für einen Tag)
for -> while
Löse nur, wenn du for-Schleifen kennst.
Schreibe als while-Schleife:
for i in range(5): print(i)
for k in range(2,13): print(k)
for j in range(10,50,5): print(j)
while -> for
Schreibe als möglichst kurze for-Schleife:
i = 5 while i < 20: i = i + 1 print(i)
i = 5 while i < 20: print(i) i = i + 3
2.21 Aufgabe
Definiere eine Funktion product(L)
, die eine Liste L
mit Zahlen entgegennimmt, deren Produkt bestimmt und zurückgibt.
2.22 Aufgabe
Schreibe eine Funktion is_prime(x)
, die eine Zahl x
entgegennimmt, entscheidet, ob diese Zahl eine Primzahl ist oder nicht und dementsprechend True/False zurückgibt.
Achtung: Diese Funktion hast du bereits einmal programmiert. Programmiere diese Funktion aber neu und ohne den alten Code anzuschauen.
2.23 Aufgabe
Bestimme die Summe aller Primzahlen $< 1000$. Verwende dazu die Funktion von der Aufgabe oben.
2.24 Aufgabe
Schreibe eine Funktion list_shift(L,x)
, der eine Liste mit Zahlen L
und eine Zahl x
übergeben wird. Die Funktion addiert zu jedem Wert in der Liste die Zahl x
. Diese modifizierte Liste wird dann zurückgegeben.
Beispiel: print(list_shift([1,2,3],5))
gibt zurück: [6, 7, 8]
2.25 Aufgabe
Zeitunterschied: Schreibe eine Funktion time_difference(h1,m1,h2,m2)
, die zwei Zeiten $h1:m1$ und $h2:m2$, z.B. $13:46$ und $17:42$ entgegennimmt und berechnet, wie viele Zeit zwischen diesen beiden Zeitpunkten liegt und zurückgibt.
2.26 Aufgabe
Schreibe eine Funktion generate_num_list(low, high, n)
, die eine Liste mit n
Zufallszahlen zwischen low
und high
zurückgibt. Benutze das Modul random
und die Funktion random.randint()
. Teste die Funktion.
2.27 Aufgabe
Schreibe eine Funktion namens maximum(liste)
, die eine Liste von Zahlen als Parameter (Argument) annimmt und das grösste Element in der Liste zurückgibt. Teste die Funktion.
2.28 Aufgabe
Schreibe eine Funktion namens quadratzahlen(liste)
, die eine Liste von Zahlen annimmt und eine neue Liste zurückgibt, in der alle Zahlen quadriert sind. Teste die Funktion.
2.29 Aufgabe
Schreibe eine Funktion namens gerade_zahlen(liste)
, die eine Liste von Zahlen annimmt und eine neue Liste zurückgibt, die nur die geraden Zahlen aus der ursprünglichen Liste enthält. Teste die Funktion.
2.30 Aufgabe
Schreibe eine Funktion namens fakultaet(n)
, die eine Zahl als Parameter annimmt und die Fakultät dieser Zahl berechnet. Die Fakultät einer Zahl n wird definiert als das Produkt aller positiven ganzen Zahlen von 1 bis n.
2.31 Aufgabe
- Schreibe eine Funktion namens
lineare_suche(li, el)
, die eine Liste und das gesuchte Element als Parameter annimmt. Die Funktion soll den Index des gesuchten Elements in der Liste zurückgeben, falls er vorhanden ist, oderNone
, wenn das Element nicht gefunden wird. - Kopiere untenstehende Listen in deinen Code.
- Schreibe Code, mit dem Du einen Namen festlegen kannst und der dann dass passende Alter ermittelt. Der Code soll eine der folgenden beiden Nachrichten ausgeben:
- „Das Alter von … ist …“ oder
- „Der Name … wurde nicht gefunden“
namen = ["Max", "Anna", "Karl", "Lisa"] alter = [25, 30, 27, 22]
2.32 Aufgabe
- Schreibe eine Funktion namens
binaere_suche(li, el)
, die eine sortierte Liste und das gesuchte Element als Parameter annimmt. Die Funktion soll im Modus der binären Suche das gesuchte Element in der Liste finden und den Index dieses Elements zurückgben. Falls das gesuchte Element nicht gefunden wird, soll die FunktionNone
zurückgeben. - Kopiere untenstehende Listen in deinen Code.
- Schreibe Code, mit dem du einen Zahl festlegen kannst und der dann die passende Beschreibung ermittelt. Der Code soll eine der folgenden beiden Nachrichten ausgeben:
- „Die Zahl … schreibt man so: ….“ oder
- „Die Zahl … wurde nicht gefunden.“
nummern = [1, 5, 10, 15, 20, 25, 30, 35] beschreibungen = ["Eins", "Fünf", "Zehn", "Fünfzehn", "Zwanzig", "Fünfundzwanzig", "Dreissig", "Fünfunddreissig"]
2.33 Aufgabe
- Schreibe eine Funktion namens
find_min(li)
, die eine Liste als Parameter annimmt, darin das kleinste Element findet und den Index dieses Elements zurückgibt. - Kopiere die Liste unten in deinen Code.
- Teste deine Funktion: Schreibe Code, der den Index des kleinsten Elements der Liste ausgibt, nämlich: 8.
gemuese = ["Tomate", "Karotte", "Brokkoli", "Zucchini", "Paprika", "Gurke", "Kartoffel", "Spinat", "Aubergine", "Spargel", "Blumenkohl", "Rote Bete"]
2.34 Aufgabe
- Schreibe eine Funktion namens
pop_min(li)
, die eine Liste als Parameter annimmt, daraus das kleinste Element entfernt und dieses zurückgibt. - Kopiere die Liste unten in deinen Code.
- Teste deine Funktion: Schreibe Code, der das kleinste Element der Liste ausgibt und anschliessend die verkürzte Liste ausgibt.
obstsorten = ["Apfel", "Banane", "Kirsche", "Orange", "Mango", "Pfirsich", "Erdbeere", "Birne", "Himbeere", "Kiwi", "Ananas", "Blaubeere"]
2.35 Aufgabe
- Schreibe eine Funktion namens
sortiere(li)
, die eine unsortierte Liste als Parameter annimmt und diese sortiert zurückgibt. - Kopiere die unsortierte Liste unten in deinen Code.
- Schreibe Code, der erst die unsortierte, dann die sortierte Liste ausgibt.
laender = ["Deutschland", "Frankreich", "Italien", "Spanien", "Kanada", "Australien", "Japan", "Brasilien", "Indien", "Mexiko", "Südafrika", "Russland"]
2.36 Aufgabe
Schreibe eine Funktion namens get_shortest(li)
, die eine Liste mit Wörtern als Parameter annimmt, darin das kürzeste Wort findet und zurückgibt. Für die Liste vornamen = [„Annamaria“, „Liam“, „Marcel“, „Leonardo“, „Mia“, „Susanna“]
zum Beispiel soll die Funktion das Element „Mia“ zurückgeben.
2.37 Aufgabe
Schreibe eine Funktion namens remove_duplicates(li)
, die alle Duplikate aus einer Liste entfernt. Die Funktion nimmt die Liste li
an und gibt eine Liste zurück, in der jeder Eintrag nur einmal enthalten ist. Beispiel: Für die Liste farben = ['gelb', 'rot', 'gelb', 'grün', 'blau', 'rot', 'rot', 'rot', 'braun', 'orange', 'orange', 'orange']
soll die Funktion die Liste ['gelb', 'rot', 'grün', 'blau', 'braun', 'orange']
zurückgeben.
2.38 Aufgabe
Schreibe eine Funktion namens boese_sieben(li)
, die eine Liste mit Zahlen annimmt, darin alle durch sieben teilbaren Elemente durch das Wort „böse“ ersetzt und die Liste zurückgibt. Beispiel: Für die Liste zahlen = [5, 9, 14, 17, 19, 21, 41, 42, 46, 49]
soll die Funktion die Liste [5, 9, 'böse', 17, 19, 'böse', 41, 'böse', 46, 'böse']
zurückgeben.
2.39 Aufgabe
Erweitere die Funktion aus der vorherigen Aufgabe, sodass auch alle Zahlen, in denen eine 7 drin vorkommt, als „böse“ erkannt werden. Also zum Beispiel auch 17, 27 und alle Zahlen von 70 bis 79. Die Funktion soll für Zahlen zwischen 1 und 99 funktionieren.
Für die Liste [5, 9, 14, 17, 19, 21, 26, 27, 28, 46, 49, 70, 73, 80]
soll die Liste [5, 9, 'böse', 'böse', 19, 'böse', 26, 'böse', 'böse', 46, 'böse', 'böse', 'böse', 80]
zurückgegeben werden.
3. Erweiterte Anforderungen
3.1 Aufgabe
Schreibe eine Funktion anzahl_ziffern(x)
, welche für eine positive ganze Zahl die Anzahl Ziffern berechnet und zurück gibt. Für die Zahl 412543 soll also 6 zurückgegeben werden. Die Verwendung von len
oder ähnlichen, vordefinierten Funktionen ist nicht erlaubt.
3.2 Aufgabe
Schreibe eine Funktion quersumme(x)
, welche die Quersumme einer positiven ganzen Zahl x berechnet und zurück gibt. Die Quersumme von 142 ist 1+4+2=7.
Tipp: Mit str(x)
kannst du eine Zahl x
in einen String umwandeln. Strings haben viele Ähnlichkeiten mit Listen: sie bestehen aus mehreren Buchstaben, genau so wie eine Zahlenliste aus mehreren Zahlen besteht.
3.3 Aufgabe
Ein Resultat aus der Mathematik besagt, dass der Wert der Reihe $$\frac1{2} + \frac1{4} + \frac1{8} + \frac1{16} + \frac1{32} + \frac1{64} + \frac1{128} + ...$$ nie den Wert 1 überschreitet, selbst wenn man unendlich viele weitere passende Summanden hinzuaddiert. Je mehr Werte man aufsummiert, desto näher gelangt man an den Wert 1. Vergewissere dich, dass dies stimmt, indem du in einer Schleife den Wert dieser Reihe für sehr viele Summanden berechnest.
3.4 Aufgabe
3.5 Aufgabe
Ziel: Das Spiel Schere-Stein-Papier programmieren. Die Benutzerin spielt das Spiel gegen den Computer. Wer zuerst 5 Punkte erreicht hat, hat gewonnen. Das Spiel kann gerne auch auf Englisch (Rock Paper Scissors) programmiert werden.
Ablauf Spiel:
- Benutzerin wirst aufgefordert, Schere (1), Stein (2) oder Papier (3) auszuwählen.
- Computer macht Zug, wählt also random Schere, Stein oder Papier aus.
- Es wird überprüft, ob Benutzerin oder Computer die Runde gewonnen hat.
- Entsprechende Ausgabe (wer hat Runde gewonnen) und aktuellen Spielstand wird ausgegeben.
- Spiel wird so lange wiederholt, bis Benutzerin oder Computer 5 Punkte erreicht hat.
- Ergebnis und Siegerin wird ausgegeben.
3.6 Aufgabe
Mit s.capitalize()
wird der String s
so umgewandelt, dass der erste Buchstabe gross und die restlichen Buchstaben klein geschrieben werden.
Programmiere diese Funktion selbst: Schreibe dazu eine eigene Funktion capitalize(s)
, die einen String s
'capizalizes'. Der umgewandelte String wird zurückgegeben.
Tipp: Verwende die vordefinierten Funktionen upper
und lower
, diese Wandeln alle Buchstaben in Gross-/Kleinbuchstaben um.
Beispiele:
capitalize("FRITZ")
ergibt"Fritz"
capitalize("monika")
ergibt"Monika"
capitalize("kAmEl")
ergibt"Kamel"
capitalize("Korrekt")
ergibt"Korrekt"
3.7 Aufgabe
Random-Word-Generator
Schreibe eine Funktion, welche ein Zufallsword generiert und zurückgibt (wende darauf deine capitalize
Funktion von oben an). Die Länge des Wortes kann vorgegeben werden oder per Zufall festgelegt werden. Das Word soll abwechslungsweise aus Vokalen und Konsonanten bestehen. Ob es mit einem Vokal oder Konsonanten beginnt, soll per Zufall bestimmt werden. Rufe die Funktion mehrfach aus und teile deiner Lehrperson das coolste Wort mit, welches dein Code erzeugt hat. Was (oder wen) würdest du so benennen?
Du kannst die folgenden zwei Listen mit Konsonanten und Vokalen verwenden:
consonants = ["B","C","D","F","G","H","J","K","L","M","N","P","Q","R","S","T","V","W","X","Z"] vowels = ["A","E","I","O","U"] #"Ä","Ö","Ü","Y"