ASCII Train Golf


60

Considera questi sette vagoni ferroviari ASCII.

Motore (E)

            __
======      \/
| [] |=========
|              )
================
 O-O-O   O-O-O \\

Autovettura (P)

===============
| [] [] [] [] |
===============
 O-O       O-O

Vagone (B)

===============
|-|-|  |  |-|-|
===============
 O-O       O-O

Autocisterna (T)

 _____---_____
(             )
===============
 O-O       O-O

Tramoggia (H)

_______________
\ | | | | | | /
===============
 O-O       O-O

Pianale (F)

===============
 O-O       O-O

Caboose (C)

    =====
====|   |====
| []     [] |
=============
 O-O     O-O

Scrivi un programma che, quando viene data una sequenza di caratteri EPBTHFC, emette la sua rappresentazione del treno ASCII, usando --per i giunti dell'auto. I caratteri di input più a sinistra diventano i vagoni ferroviari più a destra. Il treno è sempre rivolto a destra.

Ad esempio, un input di EEHTBPFCdovrebbe produrre

                                                                                                                __                __
    =====                                                                                           ======      \/    ======      \/
====|   |====                   ===============  ===============   _____---_____   _______________  | [] |=========   | [] |=========
| []     [] |                   | [] [] [] [] |  |-|-|  |  |-|-|  (             )  \ | | | | | | /  |              )  |              )
=============--===============--===============--===============--===============--===============--================--================
 O-O     O-O    O-O       O-O    O-O       O-O    O-O       O-O    O-O       O-O    O-O       O-O    O-O-O   O-O-O \\  O-O-O   O-O-O \\

Dettagli

  • Questo è il codice golf; vince il programma più breve in byte.
  • Qualsiasi sequenza di una o più lettere EPBTHFCè un input valido.
  • Il tuo programma deve essere in grado di produrre tutti e 7 i tipi di auto esattamente come appaiono sopra.
  • Accetta input dalla riga di comando o direttamente dall'utente (ad es. Finestra di messaggio). Uscita su stdout. (Le virgolette sull'input vanno bene.)
  • L'altezza dell'uscita dovrebbe essere 6 o l'altezza massima necessaria per i vagoni trainati.
  • Non posizionare i giunti ( --) nella parte anteriore della prima auto o nella parte posteriore dell'ultima auto.


Ci sarà sempre un Efronte e potrebbe esserci un punto Enel mezzo?
Martin Ender,

1
"vince il programma più breve." => contiamo byte o caratteri?
XX


1
Un'altra domanda correlata: codegolf.stackexchange.com/q/4690/9498
Justin

Risposte:


21

Perl, 265 byte

Poiché questa voce contiene byte che non corrispondono a caratteri ASCII stampabili, non può essere incollata direttamente qui. Invece, lo sto fornendo come una discarica esadecimale. Gli utenti dei sistemi Unix-ish possono ricostruire lo script fornendo al xxd -rcomando il seguente dump esadecimale :

0000000: 7573 6520 436f 6d70 7265 7373 275a 6c69  use Compress'Zli
0000010: 623b 6576 616c 2075 6e63 6f6d 7072 6573  b;eval uncompres
0000020: 7320 2778 daad 9241 6b83 3014 c7ef f914  s 'x...Ak.0.....
0000030: ef10 6add f67c 5ed6 8b06 c646 476f dda1  ..j..|^....FGo..
0000040: 3723 c183 1d85 8212 c740 087e f625 a6a3  7#.......@.~.%..
0000050: b1f6 24fd 3de1 3d7f e8fb e790 b74a 74ed  ..$.=.=......Jt.
0000060: f9f4 c3e9 25cf a328 6310 a094 6b4c 8c78  ....%..(c...kL.x
0000070: 2569 5406 8a12 8cf8 c7ab 09b1 ff71 0222  %iT..........q."
0000080: 833d da02 b874 2981 c10d 3333 df74 39c1  .=...t)...33.t9.
0000090: f531 d6dc 0f03 8f9f 9666 a12d 7021 6e7a  .1.......f.-p!nz
00000a0: 6416 2807 228e dd99 3584 c40f cc52 53ac  d.(."...5....RS.
00000b0: 9160 82a2 4559 0bcd a22c ff2e 1cc1 0e63  .`..EY...,.....c
00000c0: 9d09 6f85 25b8 13b3 8470 3fe3 5c27 a1eb  ..o.%....p?.\'..
00000d0: df5a 7735 b44d 2b86 9eb6 5fef 87dd e707  .Zw5.M+..._.....
00000e0: a5b8 219d b1ae eaed 3743 4709 f1aa d83c  ..!.....7CG....<
00000f0: f1d5 3357 257d 6be7 1039 9186 63a3 214d  ..3W%}k..9..c.!M
0000100: 9257 f607 1251 a1e7 27                   .W...Q..'

Lo script utilizza la sayfunzione Perl 5.10 e quindi deve essere eseguito con perl -M5.010. Prende un singolo argomento della riga di comando costituito dalle lettere EPBTHFCe genera la disposizione del vagone corrispondente. Ad esempio, l'input FEHproduce il seguente output:

                             __                     
                 ======      \/                     
_______________  | [] |=========                    
\ | | | | | | /  |              )                   
===============--================--===============
 O-O       O-O    O-O-O   O-O-O \\  O-O       O-O   

Il codice leggibile all'inizio dello script ha semplicemente decompresso la stringa compressa da zlib che contiene il corpo dello script e lo elimina. Il codice decompresso, a sua volta, è simile al seguente:

@a=split$/,<<'';
            __    
======      \/    
| [] |=========   
|              )  
================--
 O-O-O   O-O-O \\ 


===============  
| [] [] [] [] |  
===============--
 O-O       O-O   


===============  
|-|-|  |  |-|-|  
===============--
 O-O       O-O   


 _____---_____   
(             )  
===============--
 O-O       O-O   


_______________  
\ | | | | | | /  
===============--
 O-O       O-O   




===============--
 O-O       O-O   

    =====      
====|   |====  
| []     [] |  
=============--
 O-O     O-O   

$i=reverse pop=~y/EPBTHFC/0-6/r;
say$i=~s/./$a[6*$&+$_]/gr=~s/--$//r for 0..5

Si noti che tutti i vagoni del treno hanno le loro linee imbottite di spazi di lunghezza uniforme e includono l'accoppiamento (che viene rimosso dall'automobile più a destra dal circuito di uscita). La compressione DEFLATE utilizzata da zlib è molto efficace nel comprimere tali dati ripetitivi, quindi non è necessario provare a comprimerlo manualmente.

Si noti che questo è un primo tentativo rapido. Sono sicuro che sarebbe possibile eliminare diversi byte dalla lunghezza giocando con variazioni come riordinare i vagoni del treno nella fonte.


62

Python, 464

from curses import*
E,P,B,T,H,F,C='eJyNkM0NgDAIhe9MwVEPpBN0AxMHsKaLdHgfpVr7E+NHUyCQR4C5EiP5jKXBUeLj5ORvkDes5DtEiHeBoWo+hI36NtN9XurrRaVMQTSTEBizPo3+SGBBICLZ0/K9y0whtlDA/Gruj8SwyaRJA9tSPz16qmdTxqO9VeAvC5VloQ=='.decode('base64').decode('zlib').split('L')
i=[s.split('\n')for s in map(eval,raw_input()[::-1])]
h=max(sum(map(bool,s))for s in i)
w=initscr()
x=0
for t in i:[w.addstr(y,x,t[y+6-h])for y in range(h)];x+=len(t[-2])
w.addstr(h-2,x-2,'  ')
w.getch()
endwin()

Sono andato per un approccio usando maledizioni. Non può davvero competere, ma mi sono divertito un po '(~ 630 byte):

treno

from curses import*
E,P,B,T,H,F,C='eJyFkMENwCAIRe9M8Y/tgTiBGzTpALVxEYcvSFqiNO2DCAb8BgCnVsodu5ZEDceJlm/kPrBSniDsLCY1i6VsNDeZ6uMt1GEKMJU3ARYD1DX7F5DRBGbukZbvKeL7OkJF/nZL/wJxhrlFE6vooYtuviwlrso1JF745GMr'.decode('base64').decode('zlib').split('L')
i=[s.split('\n')for s in map(eval,raw_input()[::-1])]
h=max(sum(map(bool,s))for s in i)
w=initscr()
m=w.getmaxyx()[1]
for o in range(-sum(2+len(t[-2])for t in i),m):
 x=o
 for t in i:
  if m>x>o:w.addnstr(h-2,max(x,0),'--'[max(0,-x):],m-x);x+=2
  [w.addnstr(y,max(x,0),t[y+6-h][max(0,-x):],m-x)for y in range(h)if x<m];x+=len(t[-2])
 w.move(h,0);w.refresh();w.clear();napms(90)
endwin()

10
Caspita, quell'animazione è fantastica! (+1) Le GIF animate funzionano nei post, quindi puoi modificare l'immagine reale anziché un link, il che renderebbe la tua soluzione più elaborata. ;)
Maniglia della porta

2
@Doorknob Grazie. Inserirò l'immagine: non ero sicuro che una GIF animata sarebbe troppo fastidiosa.
GRC,

24
@grc fastidioso? sei sicuro di non voler dire FANTASTICO?
nderscore,

4
Non c'è niente di meglio di una gif di arte ASCII. +1!
Chris Cirefice,

4
Invia a Homebrew! sl2.0
Kroltan,

8

Python ( 582 488 476 450 caratteri)

import sys
A=sys.argv[1]
h=0
c='eJyVkrEKAzEIhnef4h97g9x+kOVKS7d2uK0peZE8fNXQS3NCpb+BREU/YnIhfKkUgJKpBfIsgYrnCzV9pIFBE6WDCHcWk1zbMy0PGovg/GMPw+6rujwaAY0CWtb/ESwG6NJTjNhChMxQxMy2g06/R+URtxBRRlGWC3SbY8Q1vkXgh4gz+Qb7v7Jy/US1P7TKP3NvbG3fy/V/Cw=='.decode('base64').decode('zlib').split(':')
C={}
for x in c:X=x.split('\n');C[X[0]]=X[1:-1]
for c in A:h=max(h,1+('F..CE'.find(c)+1or 3))
for y in range(6-h,6):print(' -'[y==4]*2).join(C[c][y]for c in A[::-1])

L'ascii-salad è una stringa compressa con zlib codificata in base64 contenente le figure ...


1. string.decode('base64')2. j=lambda y:y==4and'--'or' '3. rientri 1-spazio 4. for c in A[::-1]:i.append(C[c][y])5.f.append(j(y).join(i)
seequ

Inoltre, le ultime 6 righe potrebbero esserefor l in((y==4and'--'or' ').join(C[c][y]for c in A[::-1])for y in range(6-h,6)):print l
vedi il

1
Ho offerto una modifica con alcuni miglioramenti.
Seequ,

1
Pensaci, l'ultima riga potrebbe esserefor y in range(6-h,6):print(y==4and'--'or' ').join(C[c][y]for c in A[::-1])
vedi il

@TheRare Incorporated il tuo secondo (!) Miglioramento! Tuo!
max.haredoom

7

Python, 402 369

import sys
for n in range(6):
 l= sys.argv[1][::-1]
 for x,y in zip("EPBTHFC",range(0,42,6)):
  l=l.replace(x,'eJytktsNgCAMRVfpp340TMAHEziAGBZhePvgLYmGeGosXqQXSAEqIfDbWUElb0SKcF4QbUaljr0srCA6OJCC5jV7cDAyUYY6eQPlic9/kleqoKNVL6QANkmj37zohglElMzK9naJy16hhxRPR6ph/jzXB2XBS76bZpQa3Hex7Qpm1hOtg+Yb0a6PSA=='.decode('base64').decode('zlib').split('A')[y+n]).strip('-')
 print l

Grazie per i miglioramenti, Ugoren!


Grazie per aver formattato il mio codice! Sono un po 'nuovo e sinceramente non so cosa sto facendo.
Elveone,

1
Salvare alcuni caratteri: range(6),for x,y in zip("EPBTHFC",range(0,42,6)):
ugoren

4

Javascript,> 471 byte

Beh, merda, già oltre il miglior punteggio, e non ho ancora avuto modo di stampare tutto in sequenza. Ma ci ho passato un pomeriggio e volevo ancora mostrarlo.

function c(i){
    var i=i.replace(/f/,"=15r h 7h").match(/(\D)(\d+)?/g),
    s={
        's':'\\',
        'w':' []',
        'b':' |',
        'h':'O-O',
        't':'-|',
        'r':'\n'
    }
    ,
    a=[];
    for(j in i){
        x=/(\D)(\d+)?/g.exec(i[j]),
        a[j]=x[1],
        n=x[2]/1,
        o="";
        while(x[2]&&0<n--)o+=a[j];
        a[j]=o||a[j];
    }
    r=a.join('');
    for(j in s)r=r.replace(RegExp(j,"g"),s[j]);
    return r;
}
E=" 12_2r=6 6s/r|wb=9r| 14)r=16r h-O 3h-O ss",
P="r2=15r|w4brf",
B="r2=15r|t2 b bt2rf",
T="r2 _5-3_5r( 13)rf",
H="r2_15rsb6 /rf",
F="r4f",
C="r 4=5r=4| 3|=4r|w 4wbr=13r h 5h";
console.log(c(C));

Solo console.log(c(L)); // L=train car lettere stamperà una sola auto nella console. So che c'è un sacco di rifilature che potrei fare anche solo per questo, ma mi arrendo. : P


6

3
@WilliamBarbosa haha, sono ritardato. Ero tipo "Che magia è questa? Il mio codice si sta muovendo". e cercando tutto ciò che hai cambiato nello script per farlo scorrere ... poi ho spostato gli occhi su HTML. Ah, <marquee>diavolo diabolico. Perché ti hanno mai deprecato?
Phil Tune,

4
@WilliamBarbosa Credo che tu abbia individuato l'unico e il solo uso legittimo per questo tag.
Mike Clark,

3

Java (583 caratteri)

Con una compressione casalinga di base, non sono sicuro che sia così efficiente :-) La stringa del treno (ad es. EEHTBPFC) Deve essere passata come parametro.

class C{public static void main(String[]a){String s="",y="thAthA",x=" *!*h*!* A",q="vjA",r=q+x+y;String[]m=("hP78A^\\#$8A% &' %j.,A%hh) Ajj.A *!*!*8*!*!* /A"+y+q+"% &' &' &' &' %A"+r+q+"%!%!%,%,%!%!%A"+r+" [9[ A(tP)A"+r+"ss+A# % % % % % % $A"+r+y+q+x+"tPADRDAF%8%FA% &'P&' %AvRA *!*P*!* ").split("A");for(int l,z,i,j=0;j<6;j++){for(i=a[0].length()-1;i>=0;i--){z=a[0].charAt(i);r=m["EPBTHFC".indexOf(z)*6+j];for(int c:r.toCharArray()){c-=32;for(l=0;l<=c/12;l++)s+=" -=\\/|[]()O_".charAt(c%12);}if(i>0)for(l=0;l<(z=='E'&&j!=4?1:2);l++)s+=j==4?"-":" ";}s+="\n";}System.out.println(s);}}

non piegato:

class C{
    public static void main(String[]a){
        String s="",y="thAthA",x=" *!*h*!* A",q="vjA",r=q+x+y;
        String[]m=("hP78A^\\#$8A% &' %j.,A%hh) Ajj.A *!*!*8*!*!* /A"+y+q+"% &' &' &' &' %A"+r+q+"%!%!%,%,%!%!%A"+r+" [9[ A(tP)A"+r+"ss+A# % % % % % % $A"+r+y+q+x+"tPADRDAF%8%FA% &'P&' %AvRA *!*P*!* ").split("A");
        for(int l,z,i,j=0;j<6;j++){
            for(i=a[0].length()-1;i>=0;i--){
                z=a[0].charAt(i);
                r=m["EPBTHFC".indexOf(z)*6+j];
                for(int c:r.toCharArray()) {
                    c-=32;
                    for(l=0;l<=c/12;l++)
                        s+=" -=\\/|[]()O_".charAt(c%12);
                }
                if(i>0)for(l=0;l<(z=='E'&&j!=4?1:2);l++)s+=j==4?"-":" ";
            }
            s+="\n";
        }
        System.out.println(s);
    }
}

3

C #, 758 664 603 562bytes

Non un ottimo punteggio, circa 200 byte nella stringa scarsamente codificata e circa 80 byte dedicati alla decodifica. Una quantità frustrante di codice impiegato per sistemare il giunto sul motore! Ora lascia spazio vuoto nella parte anteriore del treno, che è disordinato ma all'interno delle regole, e ha anche le dimensioni della stringa di dati hard coded, cosa che inizialmente ero riluttante a fare.

using c=System.Console;class P{static void Main(){string d=c.ReadLine(),a="",z=@"99 1_5 4=78 5=5 \/1 3=|2 |3=14 29= 4_2-4_ 14_| [] |8= | []4 [] |14 | [] [] [] [] 1|-|-|1 |1 |-|-|(12 )\ | | | | | | /|13 )103= O-O4 O-O1 O-O6 O-O1 O-O6 O-O1 O-O6 O-O1 O-O6 O-O1 O-O6 O-O1 O-O-O2 O-O-O c";int j=0,e;foreach(var h in z)if(h>47&&h<58)j=j*10+h-48;else for(j++;j>0;j--)a+=h;int[]x={0,13,28,43,58,73,88,104};for(;j<6;j++){z="";foreach(var h in d)z=a.Substring(j*104+x[e="CFPBTHE".IndexOf(h)],x[e+1]-x[e])+(j==4?"--":"  ")+z;c.WriteLine(z.Replace("c ",@"\\").Trim('-'));}}}

Formattato un po ':

using c=System.Console;
class P{static void Main(){
    string d=c.ReadLine(),a="",z=@"99 1_5 4=78 5=5 \/1 3=|2 |3=14 29= 4_2-4_ 14_| [] |8= | []4 [] |14 | [] [] [] [] 1|-|-|1 |1 |-|-|(12 )\ | | | | | | /|13 )103= O-O4 O-O1 O-O6 O-O1 O-O6 O-O1 O-O6 O-O1 O-O6 O-O1 O-O6 O-O1 O-O-O2 O-O-O c";

    int j=0,e;

    foreach(var h in z)
        if(h>47&&h<58)
            j=j*10+h-48;
        else
            for(j++;j>0;j--)
                a+=h;

    int[]x={0,13,28,43,58,73,88,104};

    for(;j<6;j++)
    {
        z="";
        foreach(var h in d)
            z=a.Substring(j*104+x[e="CFPBTHE".IndexOf(h)],x[e+1]-x[e])+(j==4?"--":"  ")+z;
        c.WriteLine(z.Replace("c ",@"\\").Trim('-'));
    }
}}

La stringa viene compressa molto semplicemente sostituendo il carattere ripetuto con una rappresentazione in stringa del numero di caratteri seguito dal carattere (meno 1) o solo il carattere se ce n'è solo uno (volevo restare con ASCII ed evitare di fare nulla a livello di sub-carattere). Encoder (non incluso nel punteggio):

string compress(string str)
{
    str += (char)0; // too lazy to write a proper loop
    string res = "";

    char prev = str[0];
    int count = 1;

    for (int i = 1; i < str.Length; i++)
    {
        char cur = str[i];
        if (cur != prev)
        {
            if (count != 1)
                res += (count - 1).ToString();
            res += prev;

            prev = cur;
            count = 1;
        }
        else
        {
            count++;
        }
    }

    return res;
}

3

Ecco la mia soluzione in PHP (compatibile v5.4), 512bytes. Potrebbe essere più breve, ma ho appena creato una versione rapida per provarlo.

<?php $m=array_combine(str_split('EPBTHFC'),explode('$',gzinflate(base64_decode('jZDBDYAwCEXvfwoOHvRAnKAzOICYLtLhhVYlrY320RQI5BMgcmJEyJRUViTaD0rhRvOKBaEBtLGa1ooXmdA2FdXnJfQ0rgkW9RRYjcieRQMKupzCzNlj/t6jIxBrIDrdbR1QwH+PRaVkn107+cWM971cxPwJ'))));$t=['','','','','',''];$i=str_split(strrev(strtoupper($argv[1])));foreach($i as $w=>$n){$c=$m[$n];$c=explode("\n",$c);foreach($t as $j=>&$p){$p.=str_pad($c[$j],$n=='E'?18:($n=='C'?15:17),$j==4?'-':' ');if($w==count($i)-1)$p=rtrim($p,' -');}}echo implode("\n",$t)."\n";

Questa è una versione estesa per una facile lettura:

<?php
$m=array_combine(
    str_split('EPBTHFC'),
    explode('$',
        gzinflate(
            base64_decode(
                'jZDBDYAwCEXvfwoOHvRAnKAzOICYLtLhhVYlrY320RQI5BMgcmJEyJRUViTaD0rhRvOKBaEBtLGa1ooXmdA2FdXnJfQ0rgkW9RRYjcieRQMKupzCzNlj/t6jIxBrIDrdbR1QwH+PRaVkn107+cWM971cxPwJ'
            )
        )
    )
);
$t=['','','','','',''];
$i=str_split(strrev(strtoupper($argv[1])));
foreach($i as $w=>$n)
{
    $c=$m[$n];
    $c=explode("\n",$c);
    foreach($t as $j=>&$p)
    {
        $p.=str_pad($c[$j],$n=='E'?18:($n=='C'?15:17),$j==4?'-':' ');
        if($w==count($i)-1)$p=rtrim($p,' -');
    }
}
echo implode("\n",$t)."\n";

2

Python, 491 byte

import zlib as z,sys,base64 as d
y=eval(z.decompress(d.b64decode('eNqlksEOwiAMhl/lv1WTkd1NdtFovLmDt7HwIOK729LJmJDY6F8SyA/0g6YPOtNhIhQKAaCOhiS1fJ+siGlGHN5Sa6N9vriKLdwcB+/r7D3NHY2fYCRI7dT50kPyiM0zUCKUCiEe/yA6DkCGrKzEu5XIVWc559Iszu5bYdvEq5UYtmLH8/fW6K3Ei/mPP1W+QTxVxCVXbtklk3RnLHtG1OqYkqOU5wsfZZmx')))
w=sys.argv[1][::-1]
x=[""]*6
v=range
u=len(w)
for j in v(6):
 for i in v(u):
  if j==5 and w[i]=='E':k="\\ "
  elif j==4 and i!=u-1:k="--"
  else:k="  "
  x[j]+=y[w[i]][j]+k
for q in x:print q

Mi piace come è uscito, anche se non sarà un vincitore.


Si potrebbe cambiare if j==5...x[j]+=y[w[i]][j]+kper x[j]+=y[w[i]][j]+('\\ 'if j==5 and w[i]=='E'else'--'if j==4 and i!=u-1 else' ')risparmiare un po '. (Inoltre puoi mettere una scheda invece di due spazi davanti x[j]....)
Calvin's Hobbies

1

GNU sed , 491 byte

s/./& #/g
s:E:0S__s%1esss\\/s%2|bpef %3|Ss)%4E=@5 o-Os o-O \\\\:g
s/P/zE%3|bbbbp%4E@5ut/g
s/B/zE%3|-|-|s|s|-|-|%4E@5ut/g
s/T/z l---l %3(S )%4E@5ut/g
s:H:zlll%3\\pppppp /%4E@5ut:g
s/F/zSs %3Ss %4E@5ut/g
s/C/0S %1ssf==ss%2f=|spf=%3|bssbp%4ee=@5 ts t/g
s/z/0Ss %1Ss %2/g
s/%/s%/g
s/@/--%/g
s/u/ tss /g
s/t/os/g
s/S/ssssss/g
s/s/  /g
s/E/eef/g
s/e/ff/g
s/f/===/g
s/b/ []/g
s/p/ |/g
s/o/O-O/g
s/l/_____/g
s/^/0123456;/
:
s/([0-6])(.*;)\1([^%#]+)[%#](.*)/\1\3!\2\4/
t
s/(--!)?[1-6]/\n/g
s/[0!;]//g

Provalo online!

Spiegazione

Questo è fondamentalmente uno schema di compressione personalizzato super ingenuo. La prima riga aggiunge uno spazio a ciascuna lettera nell'input e #, per contrassegnare la fine di ogni parte:

s/./& #/g

Le successive 7 righe sostituiscono ogni lettera con una rappresentazione compressa dell'immagine ASCII corrispondente:

s:E:0S__s%1esss\\/s%2|bpef %3|Ss)%4E=@5 o-Os o-O \\\\:g
s/P/zE%3|bbbbp%4E@5ut/g
s/B/zE%3|-|-|s|s|-|-|%4E@5ut/g
s/T/z l---l %3(S )%4E@5ut/g
s:H:zlll%3\\pppppp /%4E@5ut:g
s/F/zSs %3Ss %4E@5ut/g
s/C/0S %1ssf==ss%2f=|spf=%3|bssbp%4ee=@5 ts t/g

Le successive 14 righe eseguono la "decompressione". Ad esempio, un Sdecomprime a sei ses e un sdecomprime a due spazi, quindi Sdiventa 12 spazi.

s/z/0Ss %1Ss %2/g
s/%/s%/g
s/@/--%/g
s/u/ tss /g
s/t/os/g
s/S/ssssss/g
s/s/  /g
s/E/eef/g
s/e/ff/g
s/f/===/g
s/b/ []/g
s/p/ |/g
s/o/O-O/g
s/l/_____/g

Decompressi, le linee di ogni auto sono precedute da un numero di riga e ogni auto è terminata da #. Il resto del codice antepone 0123456;(i numeri di riga e il delimitatore) allo spazio del pattern e quindi, in un ciclo, sostituisce ogni cifra con la riga corrispondente di ciascuna vettura.

s/^/0123456;/
:
  s/([0-6])(.*;)\1([^%#]+)[%#](.*)/\1\3!\2\4/
  t

Infine, taglia lo spazio del motivo in linee dividendo le cifre e pulisce i caratteri estranei:

s/(--!)?[1-6]/\n/g
s/[0!;]//g

C'è molto margine di miglioramento qui. Non ero affatto rigoroso nel trovare un set ottimale di compressioni e usare una tabella di ricerca invece di 14 s///gs separate sarebbe una vittoria facile. Potrei o no tagliarlo ancora un po '.


1

Python 3 , 529 byte

a=['']*6
T,R="EPBTHFC",{'S':' '*3,'E':'='*3,'W':'[] ','U':'_'*5,'P':'| ','H':'O-O'}
A=('SSSS__  ',)+('S'*5,)*5+('SSSS ',),('EESS\/  ',)+('S'*5,)*5+('S E==S ',),('PW|EEE ','E'*5,'E'*5,' U---U ','U'*3,'S'*5,'E=|S|E='),('P SSSS)','PWWWW|','|-|-P P |-|-|','(SSSS )','\ PPPPPP/','S'*5,'PWS W|'),('E'*5+'=--',)+('E'*5+'--',)*5+('EEEE=--',),(' H-OSH-O \\\\ ',)+(' HSS HS',)*5+(' HS  HS',)
for C in input():
 for I in range(6):
  a[I]=A[I][T.index(C)]+'  '*(I<4)+a[I]
  for k in R:a[I]=a[I].replace(k,R[k])
a[4]=a[4][:-2]
[*map(print,a)]

Provalo online!

Ho pensato di postarlo perché non utilizza alcuna compressione, a differenza della maggior parte delle altre risposte qui.


1

C (gcc) , 501 499 490 489 484 byte

-2 -9 -1 -5 byte grazie a ceilingcat .

#define A": O-Og O-O:o=:"
char*p,*q,s[80];j,k,n;main(i,a)char**a;{for(i=6;i--;puts(q))for(k=strlen(a[1]);k--;*q=0,printf("%-*s%s",j?j^6?15:13:16,s,k?i^1?!j*!i+"  ":"--":q)){j=index(p="EPBTHFC",a[1][k])-p;for(n=j*6+i,p=" O-O-Oc O-O-O \\\\:p=:|n ):| [] |i=:f=f \\/:l __"A"| [] [] [] [] |:o=::"A"|-|-|  |  |-|-|:o=::"A"(m ): e_c-e_::"A"\\ | | | | | | /:o_::"A":::: O-Oe O-O:m=:| []e [] |:d=|c |d=:d e=::";n--;)for(;*p++-58;);for(q=s;*p^58;p++)for(n=*p>96&*p<123?*p++-96:1;n--;)*q++=*p;}}

Provalo online!


@ceilingcat Cheers!
Gastropner,
Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.