Turtlèd , 135 129 bajtów (nie konkuruje)
(interpreter nie jest tak naprawdę trochę buggèd (już:]) , ale nie wpływa na ten program )
Przekształcając i przepisując mój program, grałem w golfa ... sześć bajtów
A teraz muszę wyjaśnić ...
Nadal mogą być krótsze sondy
Przynajmniej najlepszym rozwiązaniem w tym języku jest nie tylko zapisywanie surowych danych ¯ \ _ (ツ) _ / ¯
#3.141592653589793238462643383279502884197169#")()()()()()">10:[)'|l]:[)d'\l]d"(||"2uuu[|;"::"uuu];>"__"[|r'\d]dl[ l[|.+l][\r]ul]
Wypróbuj online
Wyjaśnienie
Szczerze mówiąc, nie opisuje to zbyt dobrze rzeczywistego programu, ale daje wskazówki na temat poleceń, więc możesz lepiej zrozumieć
#3.141592653589793238462643383279502884197169# Some pi. Set the string to thing between #s
the last digit was same as first, and the
string wraps, so digit could be removed
")()()()()()" Write this string, by writing char 1 to current cell, moving right, char 2...
> turn right
10 set register to ten
:[)'|l]: move right by amount in register, while current cell isn't ), write |
and move left. move right by amount in register
[)d'\l] while cell is not (, move down, write \, move left
d"(||" move down and string-write "(||"
2 set register to 2
uuu[|;"::"uuu] Move up three, and while the cell is not |, move down by
register (2), string-write "::", move up three
Just remember the turtle is currently pointing right, so up is right.
;>"__" move down by amount in register, turn right, string-write "__"
[|r'\d]dl while cell is not |{ move right, write \, move down}, move down, left
KOMPLEKSOWA RZECZ: NESTED LOOPS
[ l[|.+l][\r]ul]
Podczas gdy bieżąca komórka nie jest spacją {przesuń w lewo, wykonaj pętlę: (Podczas gdy komórka nie |, napisz bieżący znak zmiennej łańcuchowej (pamiętasz to pi?), Zwiększ wskaźnik łańcucha, przesuń w lewo), wykonaj pętlę: (gdy komórka nie \, przesuń w prawo), przesuń w górę, w lewo}