Scrivi un programma (o una funzione) che accetta una stringa non vuota di qualsiasi carattere ASCII stampabile .
Stampa (o restituisce) una catena a zig-zag dei caratteri nella stringa con ogni coppia di caratteri adiacenti collegata da:
/
se il primo carattere appare prima del secondo carattere nell'ordine ASCII normale. per esempioB / A
\
se il primo carattere appare dopo il secondo carattere nell'ordine ASCII normale. per esempioB \ A
-
se il primo e il secondo carattere sono uguali. per esempioA-A
Quindi l'output per Programming Puzzles & Code Golf
sarebbe
o
/ \
r z-z o e G l
/ \ / \ / \ / \ / \
P o r m-m n u l s & C d f
\ / \ / \ / \ / \ / \ / \ /
g a i g P e
\ /
Se nella stringa di input è presente un solo carattere, l'output sarebbe proprio quel carattere.
Il vostro programma dovrebbe trattare ,
/
, \
, e -
proprio come tutti gli altri personaggi.
ad es. -\//-- \ //-
dovrebbe produrre:
\
/ \
- /-/
/ \
- --- \ /-/
\ / \ / \
-
\
Non dovrebbero esserci newline estranee nell'output tranne una singola newline finale opzionale. (Si noti che la riga vuota nell'esempio appena sopra contiene l'ultimo spazio nella stringa e quindi non è estranea.) Potrebbero esserci spazi finali su qualsiasi riga in qualsiasi disposizione.
Vince il codice più breve in byte.
Un altro esempio: input:
3.1415926535897932384626433832795028841971693993751058209749445923078164062862089986280348253421170679
Produzione:
9 9 8 6 6
/ \ / \ / \ / \ / \
9 6 8 7 3 3 4 2 4 8 9 8-8
/ \ / \ / \ / \ / \ / \ / \
4 5 2 5 5 2 3-3 3 7 5 2 4 9 9 9-9 7
/ \ / \ / \ / \ / \ / \ / \ / \ / \
3 1 1 3 2 0 1 7 6 3 3 5 8 8 6
\ / \ / \ / \ / \ / \
. 1 1 5 2 9 9 3 7 1 4 6 8 9
\ / \ / \ / \ / \ / \ / \ / \ /
0 0 7 9 5 2 0 0 2 6 9-9 8 5 4 7
\ / \ / \ / \ / \ / \ / \ /
4 4-4 2 8 8 4 2 3 2 7 6
\ / \ / \ / \ /
0 6 8 3 1-1 0
\ / \ /
2 0
'\n'
con una stringa modello come questa