lehrkraefte:sbt:informatik:glf22:python:little-programming-tasks

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revision Previous revision
Next revision
Previous revision
lehrkraefte:sbt:informatik:glf22:python:little-programming-tasks [2022/12/09 08:14]
Karlheinz Schubert
lehrkraefte:sbt:informatik:glf22:python:little-programming-tasks [2022/12/09 22:45] (current)
Karlheinz Schubert
Line 5: Line 5:
 <WRAP center round todo> <WRAP center round todo>
   - Schau dir den Verschlüsselungsalgorithmus an, der nach dem römischen Kaiser Caesar benannt ist [[https://de.wikipedia.org/wiki/Caesar-Verschl%C3%BCsselung|Wikipedia: Caesar-Verschlüsselung]].   - Schau dir den Verschlüsselungsalgorithmus an, der nach dem römischen Kaiser Caesar benannt ist [[https://de.wikipedia.org/wiki/Caesar-Verschl%C3%BCsselung|Wikipedia: Caesar-Verschlüsselung]].
-  - Schreibe ein kleines Programm, das nach dem Veschiebewert (Quelltext) fragt und dann in einer Endlosschleife Texte verschlüsselt. Die Endlosschleife wird mit einer leeren Eingabe beendet.+  - Schreibe ein kleines Programm, das nach dem Veschiebewert (Quelltext) fragt und dann in einer Endlosschleife Texte verschlüsselt. Die Endlosschleife wird mit einer leeren Eingabe beendet.\\  
 +Zur Vereinfachung: Nutze nur kleine Buchstaben.
  
 <hidden Hinweis1> <hidden Hinweis1>
 +<code python>
 Satz = input('Quelltext: ') Satz = input('Quelltext: ')
 +</code>
 </hidden> </hidden>
 <hidden Hinweis2> <hidden Hinweis2>
Line 19: Line 22:
 </code> </code>
 </hidden> </hidden>
 +<hidden Hinweis3>
 +<code python>
 +abc = ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm',
 +       'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z']
  
 +shift = int(input("Offset: "))
  
 +while True:
 +    quelltext = input("Quelltext: ")
 +    if len(quelltext) == 0:
 +        break
 +    code = ""
 +    for buchstabe in quelltext:
 +        index = abc.index(buchstabe)
 +        indexCode = index + shift
 +        # if indexCode > len(abc) - 1:
 +        #     indexCode -= len(abc)
 +        indexCode = indexCode % len(abc)
 +        code += abc[indexCode]
 +    print(code)
 +</code>
 +</hidden>
 ---- ----
 <hidden Expertenaufgabe> <hidden Expertenaufgabe>
-Schreibe ein Verschlüsselungsprogramm, dass eine Quelltextdatei 'text.txt' einliest und als Datei 'text_encrypted.txt' auf die Festplatte schreibt.+  * Schreibe ein Verschlüsselungsprogramm, dass eine Quelltextdatei 'text.txt' einliest und als Datei 'text_encrypted.txt' auf die Festplatte schreibt.
  
 <hidden Hinweis> <hidden Hinweis>
Line 36: Line 59:
 </code> </code>
 </hidden> </hidden>
 +  * Ergänze das Programm so, dass du nach dem Dateinamen gefragt wirst und beliebig viele Dateien nacheinander verschlüsseln kannst.
 </hidden> </hidden>
 +<hidden Hinweis3>
 +  * Möglichkeit zur Verschlüsselung von beliebigen UniCode Zeichen
 +<code python>
 +c_unicode = ord("c")
 +C_unicode = ord("C")
 +print("Unicode von 'c' =", c_unicode)
 +print("Unicode von 'C' =", C_unicode)
  
 +character_65 = chr(65) 
 +character_100 = chr(220) 
 +print("Unicode 65 steht für", character_65) 
 +print("Unicode 100 steht für", character_100) 
 +# ausserhalb des englischen Alphabeths: 
 +Ue_unicode = ord("Ü"
 +print("Unicode von 'Ü' =", Ue_unicode) 
 +character_220 = chr(220) 
 +print("Unicode 220 steht für", character_220) 
 +</code> 
 +</hidden>
 </WRAP> </WRAP>
  
Line 45: Line 86:
 <WRAP center round todo> <WRAP center round todo>
 Wenn du nach einigen Prüfungen Noten hast und einen bestimmten Durchschnitt erreichen möchtest, dann kannst du die ganz leicht ausrechnen (lassen), welche Note du als nächstes schreiben musst. Wenn du nach einigen Prüfungen Noten hast und einen bestimmten Durchschnitt erreichen möchtest, dann kannst du die ganz leicht ausrechnen (lassen), welche Note du als nächstes schreiben musst.
 +  - Schreibe ein Programm, dass deine bisherigen Noten in einem Feld enthält, dich nach dem gewünschten Durchschnitt fragt und dann die Mindesnote ausgibt, die du im nächsten Test erreichen solltest. 
 +  - Verbessere das Programm so, dass du zusätzlich eingeben kannst, wieviele Tests noch anstehen, also wie viele Noten du noch bekommen kannst.
 +
 +<hidden Hinweis1>
 +<code python>
 +while True:
 +    Eingabe = input('Gewünschter Schnitt: ')
 +    if len(Eingabe) == 0:
 +        break
 +    # Umwandlung der Texteingabe in eine Dezimalzahl:
 +    WunschNote = float(Eingabe)
 +</code>
 +</hidden>
 +
 +<hidden Hinweis2>
 +<code python>
 +Noten = [4.5, 5, 3.75, 5.5]
 +Durchschnitt_ungerundet = sum(Noten)/len(Noten)
 +Durchschnitt = round(sum(Noten)/len(Noten), 2)
 +</code>
 +</hidden>
 +</WRAP>
 +
 +===== Vokabeltrainer =====
      
-* (a) Schreibe ein Programmdass deine bisherigen Noten in einem Feld enthältdich nach dem gewünschten Durchschnitt fragt und dann die Mindesnote ausgibt+<WRAP center round todo> 
 +  - Lege eine Liste mit Vokabeln an: 
 +    <code python> 
 +    Vokabeln = [ 
 +       "lesen","read" 
 +       "Apfel","apple", 
 +       "geben","give" 
 +    ] 
 +    </code> 
 +     
 +Die Vokabeln sind in Paaren hintereinander eingetragen.
  
-* (b) Verbessere das Programm so, dass du zusätzlich eingeben kannst, wieviele Tests noch anstehen, also wie viele Noten du noch bekommen kannst.+  - Frage alle Variablen der Reihe nach ab und kontrolliere, ob die Antwort richtig war. 
 +  - Erweitere das Programm um einen Abragemodus: a) Abfrage wie unter 1. und b) Zufallsabrage. Beende dies Programm wenn du eine leere Antwort eingibst. 
 +  - Ergänze eine Hilfefunktion: Gibst du als Anwort ein '?' ein, so wird die die richtige Antwort zur Frage angezeigt.
  
 +<hidden Hinweis1>
 +Da die Variablen in Paaren angeordnet sind, müssen die Indizees vielfache von zwei sein: Die abgefragte Variable 2n+0 und die Antwort 2n+1.
 +</hidden>
 +<hidden Hinweis2>
 +<code python>
 +Antwort = input(f'Übersetze "{Vokabel}": ')
 +</code>
 +</hidden>
 +----
 +<hidden Expertenaufgabe1>
 +  * Baue das Programm so um, dass du die Übersetzungsrichtung wählen kannst.
 +</hidden>
 +<hidden Expertenaufgabe2>
 +  * Erweitere das Programm so, dass du auswertest, wie viel richtige und falsche Antworten du gegeben hast. 
 +</hidden>
 +<hidden Expertenaufgabe2>
 +  * Erweitere das Programm so, dass du es für mehr als zwei Sprachen verwenden kannst. 
 +</hidden>
 +<hidden Lösung>
 +<code python>
 +"""
 +Vokabeltrainer
 +"""
 +from random import randint
 +
 +Vokabeln = [
 +    'lesen', 'read',
 +    'Apfel', 'apple',
 +    'geben', 'give',
 +    'lächeln', 'smile',
 +    'rennen', 'run'
 +]
 +Richtige = []
 +Zaehler_richtig = 0
 +Zaehler_falsch = 0
 +while True:
 +    Mode = input('de - Deutsch -> Englisch\ned - Englisch -> Deutsch: ')
 +    if Mode == 'ed' or Mode == 'de':
 +        break
 +    print('Unbekannter Mode, versuche es noch einmal!')
 +
 +while True:
 +    index = randint(0, len(Vokabeln)//2 - 1)
 +    #print(f'{index} of {len(Vokabeln)//2 - 1}')
 +    if index in Richtige:
 +        if len(Richtige)==len(Vokabeln)//2:
 +            break
 +        continue
 +    deutsch = Vokabeln[2*index]
 +    englisch = Vokabeln[2*index+1]
 +    if Mode == 'de':
 +        Frage = deutsch
 +        Antwort = englisch
 +    else:
 +        Frage = englisch
 +        Antwort = deutsch
 +    Test = input(f'Übersetze "{Frage}" ▶ ')
 +    if len(Test) == 0:
 +        break
 +    if Antwort == Test:
 +        print('richtig')
 +        Zaehler_richtig += 1
 +        Richtige.append(index)
 +    else:
 +        print('falsch')
 +        Zaehler_falsch += 1
 +
 +print(f'Du hattest {Zaehler_richtig} richtige und {Zaehler_falsch} falsche {"Antwort" if Zaehler_falsch==1 else "Antworten"}.')
 +print('fertig')
 +
 +</code>
 +</hidden>
 </WRAP> </WRAP>
  • lehrkraefte/sbt/informatik/glf22/python/little-programming-tasks.1670570089.txt.gz
  • Last modified: 2022/12/09 08:14
  • by Karlheinz Schubert