CUBE.CODES: Schleifen mit while Teil 1: Unterschied zwischen den Versionen
Zeile 93: | Zeile 93: | ||
[08:27:04] Program finished successfully | [08:27:04] Program finished successfully | ||
− | Große Zahlen haben "in der Regel" auch mehr Teiler. Aber manchmal gibt es riesige Zahlen, die trotzdem nur die "nötigsten Teiler" haben, nämlich die 1 und sich selbst! Wer findet die größte | + | Große Zahlen haben "in der Regel" auch mehr Teiler. Aber manchmal gibt es riesige Zahlen, die trotzdem nur die "nötigsten Teiler" haben, nämlich die 1 und sich selbst! Sie sind also nicht in kleinere Faktoren zerlegbar. In der 5. Klasse haben wir sie Primzahlen genannt. Sie mit Kopfrechnen zu finden, war ganz schön knackig! Wer findet die größte Primzahl mit CUBE.CODES?! |
//Siegerin Chiara | //Siegerin Chiara | ||
Zeile 104: | Zeile 104: | ||
} | } | ||
− | + | Probiert mal die um 1 kleinere Zahl aus ;-) | |
− | |||
− | |||
− | |||
− |
Aktuelle Version vom 8. Februar 2022, 08:33 Uhr
Die Möglichkeiten einer Tabellenkalkulation lassen wir spätestens dann hinter uns, wenn wir beliebige Wiederholungen von Berechnungen formulieren können. Z.B. Ist die Ausgabe eine Einmaleins nichts anderes als die Wiederholung einer Malaufgabe.
Einfache Befehle wiederholen
Programm 1: Einfache Malaufgabe
faktor1 = 5; faktor2 = 23; UI.log(faktor1*faktor2);
Bewirkt die Ausgabe:
[14:02:18] Program starting ... [14:02:19] Program running ... 115 [14:02:19] Program finished successfully
Wollen wir die Malrechnung mit größeren faktoren1 (z.B. ... bis faktor1=10) wiederholen, schreiben wir einfach while(faktor1<=10) vor den Ausgabebefehl. Allerdings müssen wir nach jeder Ausgabe faktor1 auch noch größer machen! Insgesamt ...
Programm 2: Malaufgabe wiederholen
faktor1 = 5; faktor2 = 23; while(faktor1<=10) { UI.log(faktor1*faktor2); faktor1 = faktor1 + 1; }
Bewirkt die Ausgabe:
[14:07:13] Program starting ... [14:07:13] Program running ... 115 138 161 184 207 230 [14:07:13] Program finished successfully
Wir kürzen faktor1 und faktor2 auch noch etwas ab, verbessern die Ausgabe, lassen das Ganze von 1 bis 10 laufen und schon haben wir ein nettes Programm, das ein Einmaleins ausgibt:
Programm 3: Einmaleins ausgeben
x=1; y=364; ergebnis=x*y; while(x<=10) { UI.log(x + " mal " + y + " ist " + ergebnis); x=x+1; ergebnis=x*y; }
... bewirkt ...
[08:37:01] Program starting ... [08:37:01] Program running ... 1 mal 364 ist 364 2 mal 364 ist 728 3 mal 364 ist 1092 4 mal 364 ist 1456 5 mal 364 ist 1820 6 mal 364 ist 2184 7 mal 364 ist 2548 8 mal 364 ist 2912 9 mal 364 ist 3276 10 mal 364 ist 3640 [08:37:01] Program finished successfully
Teiler einer Zahl finden
Statt der Vielfachen einer Zahl, können wir durch Wiederholung auch die Teiler einer Zahl finden - was händisch sehr mühsam ist...
Teiler=1; Zahl=12; while(Teiler<=Zahl) { if(Zahl%Teiler==0) UI.log(Teiler); ++Teiler; }
liefert die Teiler...
[08:27:03] Program starting ... [08:27:04] Program running ... 1 2 3 4 6 12 [08:27:04] Program finished successfully
Große Zahlen haben "in der Regel" auch mehr Teiler. Aber manchmal gibt es riesige Zahlen, die trotzdem nur die "nötigsten Teiler" haben, nämlich die 1 und sich selbst! Sie sind also nicht in kleinere Faktoren zerlegbar. In der 5. Klasse haben wir sie Primzahlen genannt. Sie mit Kopfrechnen zu finden, war ganz schön knackig! Wer findet die größte Primzahl mit CUBE.CODES?!
//Siegerin Chiara Teiler=1; Zahl=999999751; while(Teiler<=Zahl) { if(Zahl%Teiler==0) UI.log(Teiler); ++Teiler; }
Probiert mal die um 1 kleinere Zahl aus ;-)