Hintergrund
Manufactoria wurde als Spiel vermarktet, aber wir Code-Golfer können es als das sehen, was es wirklich ist: eine zweidimensionale Programmiersprache. Die Programmiersprache Manufactoria basiert auf einer einzelnen Warteschlange , die eine Reihe bunter Markierungen enthält. Der Anweisungszeiger bewegt sich mit Förderbändern auf dem Spielbrett und trifft auf eine Reihe von Schreibern und Zweigen, die aus der Warteschlange lesen und in diese schreiben.
Die Sprache ist sehr leicht zu verstehen. Der schnellste Weg, sie zu erlernen, besteht darin, die ersten Level des Spiels zu spielen (siehe oben).
Herausforderung
Ihre Herausforderung besteht darin, ein Programm zu erstellen, das in kürzester Zeit eine Zahl durch eine andere Zahl teilen kann.
Die Eingabe in das Programm besteht aus einer Folge von X blauen Markierungen, gefolgt von Y roten Markierungen. Die erforderliche Ausgabe ist eine Reihe roter Markierungen mit einer Länge von X / Y.
Das zu verwendende Spielbrett befindet sich in diesem offiziellen Wettbewerbslevel:
Es ist 13x13 (die maximale Größe) und mit den richtigen Tests ausgestattet (siehe Abschnitt Bewertung).
Wertung
Die Punktzahl Ihres Programms gibt die Gesamtzeit an, die das Programm benötigt, um alle Tests in der offiziellen Wettbewerbsstufe zu bestehen. Die Gesamtzeit wird auf dem Level-Complete-Bildschirm angezeigt.
Während Sie die Tests ausführen, müssen Sie höchstwahrscheinlich den 50-fachen Beschleunigungsregler unten links verwenden, um die Ergebnisse schnell zu erhalten (Zeitbeschleunigung hat keinen Einfluss auf die Punktzahl).
Hier ist eine Liste der Teilungsprobleme, die an den Tests beteiligt sind:
6/2 = 3
3/3 = 1
4/1 = 4
0/1 = 0
12/4 = 3
12/3 = 4
9/3 = 3
10/2 = 5
Beispiel E / A.
12/3=4
in: BBBBBBBBBBBBRRR
out: RRRR
10/2=5
in: BBBBBBBBBBRR
out: RRRRR
9/3=3
in: BBBBBBBBBRRR
out: RRR
0/1=0
in: R
out:
quelle
Antworten:
Ergebnis 3:29
Könnte auch Sonderfall dividieren durch 1,2,3,4. Macht es viel schneller.
http://pleasingfungus.com/Manufactoria/?lvl=34&code=c9:13f2;c10:13f2;c11:13f2;p12:2f7;y13:2f0;p11:2f0;c11:4f3;c10:3f0;p11:5f0 ; c10: 5f0; c9: 5f0; c11: 6f3; p11: 7f0; c10: 7f0; p11: 3f0; r10: 6f1; q8: 5f4; q8: 6f1; q9: 6f1; c7: 5f3; c7: 6f3; q10 : 2f0; r10: 1f3; r10: 4f1; q9: 3f4; q9: 4f1; c9: 2f3; c8: 3f3; c8: 4f3; r10: 8f1; q10: 9f6; q9: 9f1; q9: 8f4; q9: 7f4 ; c8: 8f3; c8: 9f3; c8: 10f3; c8: 11f3; c8: 12f3; c8: 13f2; c7: 7f2; c8: 7f3; r11: 9f3; r11: 10f0; r10: 10f0; r9: 10f3; r9 : 11f2; p11: 11f6; r11: 12f1; g11: 8f3; b10: 11f2; c16: 10f2; q17: 10f6; q17: 11f3; g18: 11f0; c12: 11f1; c12: 10f2; c13: 10f2; c14: 10f2 ; c15: 10f2; c17: 12f0; p16: 12f4; c16: 11f3; c16: 13f1; q15: 12f0; r15: 13f1; c14: 12f3; c14: 13f0; c13: 13f0; q17: 7f6; q17: 9f1; q18 : 9f6; q18: 8f5; q17: 6f1; g16: 6f2; y18: 6f0; p17: 5f5; r18: 5f0; c16: 5f0; p15: 5f0; r15: 6f3; b15: 7f2; p16: 7f6; r16: 8f1 ; q14: 5f0; y14: 4f3; g14: 6f1; p13: 5f0; p13: 6f0; p13: 7f0; p13: 8f0; p13: 9f1; g12: 9f0; c17: 8f1; & ctm = Divide_and_Conquer;Input_will_be_X_blues_followed_by_Y_reds, _output_X / Y_reds; bbbbbbrr: rrr | bbbrrr: r | bbbbr: rrrr | r: |;;
quelle
Ergebnis: 15:51
Teilung durch wiederholte Subtraktion. Verwendet ein Y unter dem R, um zu verfolgen, wie viel Divisor wir bisher subtrahiert haben. Verwendet Gs, um den Quotienten zu zählen.
Zum Beispiel ist der Zustand am Anfang jeder äußeren Schleife (direkt nach dem anfänglichen G-Writer) für 12/4:
Wenn kein Bs mehr vorhanden ist, entfernt das Gadget unten links Rs und gibt dann # G-1 Rs aus.
Die innere Schleife entfernt jeweils ein B und verwendet Y, um die Position zu verfolgen. Beginnend an der äußeren Schleife:
Die innere Schleife ist die 3x4-Box unten rechts. Das Layout des Restes kann wahrscheinlich etwas verbessert werden, aber die innere Schleife ist eng.
http://pleasingfungus.com/Manufactoria/?lvl=34&code=c11:13f2;g12:2f3;p12:3f7;c13:3f3;p13:4f3;b12:4f2;r14:4f3;p14:7f7;r13:7f2 ; q14: 8f7; g13: 8f2; p14: 9f4; r13: 10f2; p14: 10f7; b15: 10f0; q14: 11f7; p15: 11f3; r16: 11f1; p15: 8f0; r15: 9f1; c16: 8f0; c13 : 2f0; c15: 2f0; c16: 2f0; c17: 2f0; c11: 3f3; c11: 4f3; c11: 6f3; c11: 7f3; c11: 8f3; c11: 9f3; c11: 5f3; p11: 10f7; q11: 11f6 ; q11: 12f7; r10: 12f2; c10: 10f2; q16: 10f5; y14: 6f3; q14: 5f3; g15: 5f1; c15: 4f1; c15: 3f1; c17: 9f1; c17: 8f1; c17: 7f1; c17 : 6f1, c17, 5f1, c17, 4f1, c17, 3f1, y16, 9f1, g17, 10f1, q14, 2f4, g14, 1f3, & ctm : rrrr | r: | bbbbbbbbbbbrrrr: rrr | bbbbbbbbbbrrr: rrrr | bbbbbbbbrrr: rrr | bbbbbbbbbrr: rrrrr; 13; 3; 0 ;
quelle
Ergebnis 20:35
Ein ganz anderer Ansatz - weniger Teile, aber deutlich langsamer.
http://pleasingfungus.com/Manufactoria/?lvl=34&code=p12:2f3;g11:2f3;b11:3f3;c12:4f2;c11:4f2;c13:2f3;c13:3f3;c13:4f3;c12:5f3 ; c11: 5f1; c10: 5f2; c9: 8f3; c9: 9f3; c10: 11f2; c11: 11f1; c11: 9f1; c11: 10f1; c11: 12f2; c13: 8f0; c11: 8f0; c13: 7f0; c14 : 7f0; c14: 6f3; c12: 7f3; y14: 5f0; y10: 6f1; y11: 7f1; g12: 6f2; g9: 11f2; g10: 10f0; q9: 10f3; q13: 5f7; q13: 6f7; b11: 6f1 ; b10: 9f1; p10: 7f1; r9: 7f2; p10: 8f4; p12: 8f3; q12: 12f3; r13: 12f0; r8: 10f2; c12: 9f3; c12: 10f3; c12: 11f3; ctm = Divide_and_Conquer; , _output_X / Y_reds; bbbbbbrr: RRR | bbbrrr: r | bbbbr: rrrr | r: | bbbbbbbbbbbbrrrr: RRR | bbbbbbbbbbbbrrr: rrrr | bbbbbbbbbrrr: RRR | bbbbbbbbbbrr: rrrrr; 13; 3; 0 ;
quelle