Diese Herausforderung ist locker vom nicht implementierten Esolang Pada inspiriert .
Es sei ein Array von 8 Bits betrachtet, die alle auf Null initialisiert sind. Wir werden einen sehr minimalistischen Befehlssatz einführen, um beliebige Zeichenfolgen zu drucken. Es gibt zwei Befehle, die beide einen Parameter annehmen, N
der der Index eines Bits ist:
t N
für t oggle: Dadurch ändert sich der Wert von BitN
.p N
for p rint: Dies interpretiert alle 8 Bits als Byte, beginnend mit BitN
und umlaufend am Ende . Das diesem Byte entsprechende Zeichen wird auf STDOUT gedruckt.
Schauen wir uns ein Beispiel an. Wir wollen drucken :=
. Naiv erreichen wir dies wie folgt (0-basierte Bitindizes):
t 2 [0 0 1 0 0 0 0 0]
t 3 [0 0 1 1 0 0 0 0]
t 4 [0 0 1 1 1 0 0 0]
t 6 [0 0 1 1 1 0 1 0]
p 0 [0 0 1 1 1 0 1 0] == 58 == ':'
t 5 [0 0 1 1 1 1 1 0]
t 6 [0 0 1 1 1 1 0 0]
t 7 [0 0 1 1 1 1 0 1]
p 0 [0 0 1 1 1 1 0 1] == 61 == '='
Stattdessen können wir die zyklische Funktion nutzen p
und zwei Anweisungen speichern:
t 2 [0 0 1 0 0 0 0 0]
t 3 [0 0 1 1 0 0 0 0]
t 4 [0 0 1 1 1 0 0 0]
t 6 [0 0 1 1 1 0 1 0]
p 0 [0 0 1 1 1 0 1 0] == 58 == ':'
t 1 [0 1 1 1 1 0 1 0]
p 7 [0 1 1 1 1 0 1 0] == [0 0 1 1 1 1 0 1] == 61 == '='
^
p 7
Beginnt also einfach, den Bytewert vom letzten statt vom ersten Bit zu lesen.
Die Herausforderung
Erstellen Sie bei einer nicht leeren Zeichenfolge aus druckbaren ASCII-Zeichen (einschließlich 0x20 bis 0x7E) eine optimale Anweisungsliste (eine Zeile pro Anweisung), um diese Zeichenfolge mit dem obigen System zu drucken. Wenn es mehrere optimale Lösungen gibt (was fast immer der Fall sein wird), generieren Sie nur eine davon.
Sie können für die Bits zwischen 0-basierter und 1-basierter Indizierung wählen, geben Sie jedoch Ihre Wahl an.
Sie können ein Programm oder eine Funktion schreiben, indem Sie eine Eingabe über STDIN (oder die nächstgelegene Alternative), ein Befehlszeilenargument oder ein Funktionsargument vornehmen und das Ergebnis über STDOUT (oder die nächstgelegene Alternative), einen Funktionsrückgabewert oder einen Funktionsparameter (out) ausgeben. Wenn Sie das Ergebnis nicht an STDOUT ausgeben, sollte es sich weiterhin um eine einzelne durch Zeilenumbrüche getrennte Zeichenfolge handeln.
Dies ist Codegolf, daher gewinnt die kürzeste Antwort (in Bytes).
Testfälle
Jeder Testfall ist eine einzelne Zeile mit der Eingabezeichenfolge, gefolgt von der optimalen Anzahl von Anweisungen und einer möglichen Lösung.
Sie sollten die Anweisungsanzahl in Ihrer Lösung nicht ausgeben - dies ist nur hier enthalten, damit Sie die Richtigkeit Ihres Codes überprüfen können, wenn eine andere Anweisungsliste gedruckt wird.
?
7 instructions
t 2
t 3
t 4
t 5
t 6
t 7
p 0
:=
7 instructions
t 2
t 3
t 4
t 6
p 0
t 1
p 7
0123456789
26 instructions
t 2
t 3
p 0
t 7
p 0
t 6
t 7
p 0
t 7
p 0
t 5
t 6
t 7
p 0
t 7
p 0
t 6
t 7
p 0
t 7
p 0
t 2
t 3
p 3
t 2
p 3
9876543210
28 instructions
t 2
t 3
t 4
t 7
p 0
t 7
p 0
t 0
t 7
p 5
t 4
p 5
t 0
t 5
p 0
t 7
p 0
t 5
t 6
t 7
p 0
t 7
p 0
t 6
t 7
p 0
t 7
p 0
Hello, World!
39 instructions
t 1
t 4
p 0
t 3
t 7
p 2
t 1
t 6
p 2
p 2
t 0
t 1
p 2
t 0
t 1
t 3
p 2
t 6
t 7
p 2
t 0
t 2
t 6
t 7
p 1
t 0
t 1
t 5
p 0
t 2
t 7
p 3
t 2
t 6
p 0
t 4
p 0
t 1
p 3
The quick brown fox jumps over the lazy dog.
150 instructions
t 1
t 3
t 5
p 0
t 1
t 2
p 1
t 1
t 3
t 7
p 0
t 1
t 5
t 7
p 0
t 1
t 3
t 7
p 0
t 5
p 0
t 3
t 4
t 5
p 0
t 4
t 6
p 0
t 4
p 0
t 1
t 4
t 6
t 7
p 0
t 1
t 6
p 0
t 3
p 0
t 0
t 5
p 4
t 0
t 7
p 0
t 1
p 1
t 3
t 5
t 6
t 7
p 0
t 1
t 5
t 6
p 0
t 4
t 7
p 0
t 1
t 2
p 3
t 5
t 6
t 7
p 2
t 1
t 2
t 6
p 0
t 0
p 7
t 0
t 7
p 5
t 3
t 4
t 6
t 7
p 0
t 6
t 7
p 0
t 1
t 3
t 6
t 7
p 0
t 1
t 4
t 5
t 6
t 7
p 0
t 4
p 4
t 6
p 0
t 1
t 6
p 4
t 5
t 6
t 7
p 0
t 1
t 3
t 5
p 0
t 1
p 1
t 1
t 3
t 7
p 0
t 1
t 5
t 7
p 0
t 1
t 4
t 5
p 0
t 1
p 3
t 3
t 7
p 1
t 1
t 5
p 0
t 1
t 3
t 4
t 7
p 0
t 1
t 5
p 0
t 4
t 6
t 7
p 0
t 4
p 0
t 1
t 4
t 7
p 0
Die Testfälle wurden mit dieser CJam-Referenzimplementierung generiert .