CUBE.CODES: Schleifen mit for
Programm 1: für(... ) tu: ...;
//Wiederholungen mit for for(i=1; i<1000; i=i+1) UI.log(i);
Programm 1a: Was tut sich während der Wiederholung? - Wiederhole ganze Programmblöcke
//Wiederholungen ganzer Blöcke x=1; while(x<101) { x=x+1; UI.log(x); }
Man kann also ganz offensichtlich durch Schleifen in einem Programm Berechnungen beliebig oft - auch variiert - wiederholen und dadurch viel mächtigere Berechnungen realisieren als in einer Tabellenkalkulation, in der wir immer nur einen Term für eine Berechnung formulieren konnten.
Das Gaußsche Kinderwunder
Von Carl Friedrich Gauß (* 30. April 1777 in Braunschweig, † 23. Februar 1855 in Göttingen) geht die Geschichte um, dass er in der 1. Klasse Grundschule schon seine erste Mathematische Erfindung tätigte, als sein Lehrer der Klasse die Übungsaufgabe aufgab: Addiert alle Zahlen von 1 bis 100!
Der kleine Carl Friedrich soll sich sogleich gemeldet haben mit der Antwort 5050. Wie hat er das wohl gemacht? Schließlich ist ...
1 + 2 + 3 + 4 + 5 + ... + 98 + 99 + 100 =
... ja für Erstklässler keine "Aufgabe auf einen Blick". Tja hängt wohl vom persönlichen Blick ab! JavaSkript kann da etwas hölzerner vorgehen ...:
Programm 2: Das Gaußsche Kinderwunder
//Das Gaußsche Kinderwunder x=1; summe=0; while(x<=100) { summe=summe+x; UI.log(summe); x=x+1; }
Programm 2a: JavaScript hat als Ableger der Abkürzungsfanatikersprache C einige solche Tipps für uns parat ...
//Das Gaußsche Kinderwunder x=0; summe=0; while(++x<=100) summe+=x; UI.log(summe);
Programm 3: Den Zauberwürfel bewegen
//Was passiert, wenn ich einen MOVE immer wieder mache? await CUBE.move(" E R "); while(!CUBE.isSolved()) await CUBE.move(" E R "); //Probier's mal mit dem MOVE RBLF! :-) Viel Spaß!
Lässt man die erste Codezeile weg, klingt das Programm auch umgangssprachlich vernünftig, "funktioniert aber nicht"! Probier's! Natürlich funktioniert die Schleife. Sie macht, was sie soll, nämlich: Den Zug ausführen, solange der Würfel ungelöst ist. Aber der Würfel ist ja am Anfang gelöst. Also alles richtig! Die Schleife wird nicht mal ein einziges Mal ausgeführt, weil die Wiederholungsbedingung ja schon beim ersten Mal nicht erfüllt ist.
Gibt es nicht eine einfachere Möglichkeit, zu sagen, dass der PC die Schleife auf jeden Fall einmal macht und erst vor der wirklichen Wiederholung die Bedingung abfragt? Sonst müsste man (auch bei längeren Wiederholungsblöcken) immer den Befehlsblock nochmal extra vor die Schleife kopieren, damit der PC den Block einmal ausführt und dann erst über die Wiederholung berät!
Die Lösung ist Programm 3a: Mach {... } solange(... )
do await CUBE.move(" E R "); while(!CUBE.isSolved())
Programm 3b: Ich möchte mitzählen
i=0; do { await CUBE.move(" E R "); ++i; } while(!CUBE.isSolved()) UI.log(i);
CUBE muss also den Zug (E R) acht mal ausführen, damit der CUBE wieder so aussieht, wie am Anfang. Das ist übrigens bei jedem Zug so, dass er irgendwann zum gelösten Zustand zurückkehrt. Man nennt diese Zahl die Ordnung(E R)!
Bestimme die Ordnungen der folgenden Züge:
- F2 R2 U2 F' B D2 L2 F B (Ordnung 6)
- R' y (Ordnung 1206)
- M' S' M S (Ordnung 3)
- L M R D E U B S F (Ordnung 4)
Finde Züge mit möglichst großer Ordnung!