Klasse 5-6
Klasse 7-8
Klasse 9-10
Kursstufe
cosh
nach Aufgabentypen suchen
Aufgabentypen anhand von Beispielen durchstöbern
Browserfenster aktualisieren (F5), um neue Beispiele bei den Aufgabentypen zu sehen
Modulo addieren
Beispiel:
Berechne ohne WTR: (24003 + 800) mod 8.
Um längere Rechnungen zu vermeiden, rechnen wir:
(24003 + 800) mod 8 ≡ (24003 mod 8 + 800 mod 8) mod 8.
24003 mod 8 ≡ 3 mod 8 kann man relativ leicht bestimmen, weil ja 24003
= 24000
800 mod 8 ≡ 0 mod 8 kann man relativ leicht bestimmen, weil ja 800
= 800
Somit gilt:
(24003 + 800) mod 8 ≡ (3 + 0) mod 8 ≡ 3 mod 8.
Modulo multiplizieren
Beispiel:
Berechne ohne WTR: (70 ⋅ 87) mod 7.
Um längere Rechnungen zu vermeiden, rechnen wir:
(70 ⋅ 87) mod 7 ≡ (70 mod 7 ⋅ 87 mod 7) mod 7.
70 mod 7 ≡ 0 mod 7 kann man relativ leicht bestimmen, weil ja 70 = 70 + 0 = 10 ⋅ 7 + 0 ist.
87 mod 7 ≡ 3 mod 7 kann man relativ leicht bestimmen, weil ja 87 = 84 + 3 = 12 ⋅ 7 + 3 ist.
Somit gilt:
(70 ⋅ 87) mod 7 ≡ (0 ⋅ 3) mod 7 ≡ 0 mod 7.
modulo Potenzieren einfach
Beispiel:
Berechne möglichst geschickt: 1928 mod 263.
Die 8 im Exponent ist ja ein reine 2er-Potenz (23).
Deswegen quadrieren wir einfach mit jedem Schritt das Ergebnis und kommen so immer eine 2er-Potenz im Exponenten höher:
Zur technischen Durchführung mit einem TI-WTR bietet sich folgende Vorgehensweise an:
1. 192 -> x
2. mod(x²,263) -> x
- den Pfeil "->" erhält man durch Drücken der [sto->]-Taste
- die x-Taste ist direkt darüber
- "mod" erhält man durch [math]->NUM->8:mod
- das Komma "," erhält man durch Drücken von [2nd][.]
1: 1921=192
2: 1922=1921+1=1921⋅1921 ≡ 192⋅192=36864 ≡ 44 mod 263
4: 1924=1922+2=1922⋅1922 ≡ 44⋅44=1936 ≡ 95 mod 263
8: 1928=1924+4=1924⋅1924 ≡ 95⋅95=9025 ≡ 83 mod 263
modulo Potenzieren große Zahlen
Beispiel:
Berechne möglichst geschickt: 450104 mod 797.
Wir berechnen zuerst mal alle 2er-Potenzen, die kleiner sind 104 (grauer Kasten).
Dann schauen wir die Binärdarstellung von 104 an und zerlegen 104 in eine Summer von 2er-Potenzen:
104 = 64+32+8
1: 4501=450
2: 4502=4501+1=4501⋅4501 ≡ 450⋅450=202500 ≡ 62 mod 797
4: 4504=4502+2=4502⋅4502 ≡ 62⋅62=3844 ≡ 656 mod 797
8: 4508=4504+4=4504⋅4504 ≡ 656⋅656=430336 ≡ 753 mod 797
16: 45016=4508+8=4508⋅4508 ≡ 753⋅753=567009 ≡ 342 mod 797
32: 45032=45016+16=45016⋅45016 ≡ 342⋅342=116964 ≡ 602 mod 797
64: 45064=45032+32=45032⋅45032 ≡ 602⋅602=362404 ≡ 566 mod 797
450104
= 45064+32+8
= 45064⋅45032⋅4508
≡ 566 ⋅ 602 ⋅ 753 mod 797
≡ 340732 ⋅ 753 mod 797 ≡ 413 ⋅ 753 mod 797
≡ 310989 mod 797 ≡ 159 mod 797
Es gilt also: 450104 ≡ 159 mod 797
erweiterter Euklid'scher Algorithmus
Beispiel:
Berechne mit Hilfe des erweiterten Euklid'schen Algorithmus das Modulo-101-Inverse zur Zahl 52.
Also bestimme x, so dass 52 ⋅ x ≡ 1 mod 101 gilt:
Berechnung des größten gemeinsamen Teilers von 101 und 52
| =>101 | = 1⋅52 + 49 |
| =>52 | = 1⋅49 + 3 |
| =>49 | = 16⋅3 + 1 |
| =>3 | = 3⋅1 + 0 |
also gilt: ggt(101,52)=1
Jetzt formen wir jede Zeile von unten nach oben um indem wir das Prokukt auf die andere Seite bringen.
Wir starten mit der zweitletzten Zeile:
| 1= 49-16⋅3 | |||
| 3= 52-1⋅49 | eingesetzt in die Zeile drüber: | 1 |
= 1⋅49 -16⋅(52 -1⋅ 49)
= 1⋅49 -16⋅52 +16⋅ 49) = -16⋅52 +17⋅ 49 (=1) |
| 49= 101-1⋅52 | eingesetzt in die Zeile drüber: | 1 |
= -16⋅52 +17⋅(101 -1⋅ 52)
= -16⋅52 +17⋅101 -17⋅ 52) = 17⋅101 -33⋅ 52 (=1) |
Es gilt also: ggt(101,52)=1 = 17⋅101 -33⋅52
oder wenn man 17⋅101 auf die linke Seite bringt:
1 -17⋅101 = -33⋅52
-33⋅52 = -17⋅101 + 1 |+101⋅52
-33⋅52 + 101⋅52 = -17⋅101 + 101⋅52 + 1
(-33 + 101) ⋅ 52 = (-17 + 52) ⋅ 101 + 1
68⋅52 = 35⋅101 + 1
Es gilt also: 68⋅52 = 35⋅101 +1
Somit 68⋅52 = 1 mod 101
68 ist also das Inverse von 52 mod 101
Schlüsselpaar für RSA
Beispiel:
Berechne mit dem RSA-Verfahren ein Schlüsselpaar zu den beiden Primzahlen p = 47 und q = 37. Aus Sicherheitsgründen sollte der selbst gewählte geheime Schlüssel nicht zu klein sein, hier also mindestens 500.
