Parole dentro parole dentro parole dentro parole. . .


17

In questo font pixelato di lettere maiuscole dell'alfabeto, tutti i personaggi sono larghi 5 unità e alti 5.

 ███  ████   ███  ████  █████ █████  ████ █   █ █████     █ █   █ █     █   █
█   █ █   █ █   █ █   █ █     █     █     █   █   █       █ █  █  █     ██ ██
█████ ████  █     █   █ ████  ████  █  ██ █████   █       █ ███   █     █ █ █
█   █ █   █ █   █ █   █ █     █     █   █ █   █   █   █   █ █  █  █     █   █
█   █ ████   ███  ████  █████ █      ████ █   █ █████  ███  █   █ █████ █   █

█   █  ███  ████   ███  ████   ████ █████ █   █ █   █ █   █ █   █ █   █ █████
██  █ █   █ █   █ █   █ █   █ █       █   █   █ █   █ █   █  █ █   █ █     █ 
█ █ █ █   █ ████  █   █ ████   ███    █   █   █  █ █  █ █ █   █     █     █  
█  ██ █   █ █     █  ██ █  █      █   █   █   █  █ █  █ █ █  █ █    █    █   
█   █  ███  █      ████ █   █ ████    █    ███    █    █ █  █   █   █   █████

C'è anche 1 unità di spazio tra le lettere e tra le linee, come si può vedere. Quindi ogni lettera può richiedere fino a 6 × 6 unità di spazio.

Supponiamo che invece di utilizzare il carattere di blocco completo ( ) per formare direttamente le forme delle lettere, volessimo usare altre lettere nello stesso carattere . Questo implica aumentare le dimensioni del testo 6 volte in modo che le lettere fatte di blocchi interi possano essere utilizzate come sostituzioni di blocchi completi nel testo più grande.

Se ciò non avesse senso, si spera che questo esempio lo farà. Ecco una A fatta di B usando il carattere pixelato:

      ████  ████  ████       
      █   █ █   █ █   █      
      ████  ████  ████       
      █   █ █   █ █   █      
      ████  ████  ████       
                             
████                    ████ 
█   █                   █   █
████                    ████ 
█   █                   █   █
████                    ████ 
                             
████  ████  ████  ████  ████ 
█   █ █   █ █   █ █   █ █   █
████  ████  ████  ████  ████ 
█   █ █   █ █   █ █   █ █   █
████  ████  ████  ████  ████ 
                             
████                    ████ 
█   █                   █   █
████                    ████ 
█   █                   █   █
████                    ████ 
                             
████                    ████ 
█   █                   █   █
████                    ████ 
█   █                   █   █
████                    ████ 

Le B sono fatte di blocchi interi e la A è fatta di B. Notare che le B hanno ancora un'unità tra loro in orizzontale e in verticale.

Possiamo estendere questa idea usando parole anziché solo lettere. Ecco "ACQUA" fatta di "FUOCO":

█████                   █████             ████  █████ █████             █████ ████  █████ █████ █████       ████  █████ █████ █████ ████        █████ █████ █████ ████       
█                         █               █   █ █     █                   █   █   █ █     █       █         █   █ █     █       █   █   █       █     █       █   █   █      
████                      █               ████  ████  ████                █   ████  ████  ████    █         ████  ████  ████    █   ████        ████  ████    █   ████       
█                         █               █  █  █     █                   █   █  █  █     █       █         █  █  █     █       █   █  █        █     █       █   █  █       
█                       █████             █   █ █████ █                 █████ █   █ █████ █     █████       █   █ █████ █     █████ █   █       █████ █     █████ █   █      
                                                                                                                                                                             
█████                   █████       ████                    █████                   █████                   █████                               ████                    █████
█                         █         █   █                   █                       █                         █                                 █   █                   █    
████                      █         ████                    ████                    ████                      █                                 ████                    ████ 
█                         █         █  █                    █                       █                         █                                 █  █                    █    
█                       █████       █   █                   █████                   █                       █████                               █   █                   █████
                                                                                                                                                                             
█████       █████       ████        █████ █████ █████ ████  █████                   █████                   █████ ████  █████ █████             █████ ████  █████ █████      
█             █         █   █       █     █       █   █   █ █                       █                         █   █   █ █     █                   █   █   █ █     █          
████          █         ████        ████  ████    █   ████  ████                    ████                      █   ████  ████  ████                █   ████  ████  ████       
█             █         █  █        █     █       █   █  █  █                       █                         █   █  █  █     █                   █   █  █  █     █          
█           █████       █   █       █████ █     █████ █   █ █████                   █                       █████ █   █ █████ █                 █████ █   █ █████ █          
                                                                                                                                                                             
█████       █████       ████        █████                   █████                   █████                   ████                                █████             █████      
█             █         █   █       █                       █                         █                     █   █                               █                 █          
████          █         ████        ████                    ████                      █                     ████                                ████              ████       
█             █         █  █        █                       █                         █                     █  █                                █                 █          
█           █████       █   █       █████                   █                       █████                   █   █                               █████             █          
                                                                                                                                                                             
      █████       █████             ████                    █████                   █████                   █████ ████  █████ █████ █████       ████                    █████
      █             █               █   █                   █                       █                         █   █   █ █     █       █         █   █                   █    
      ████          █               ████                    ████                    ████                      █   ████  ████  ████    █         ████                    ████ 
      █             █               █  █                    █                       █                         █   █  █  █     █       █         █  █                    █    
      █           █████             █   █                   █████                   █                       █████ █   █ █████ █     █████       █   █                   █████

Notare come "FUOCO" appare ripetutamente su ogni riga e sempre in ordine, indipendentemente dallo spazio tra le lettere. Tre dei casi più a destra di "FUOCO" sono stati tagliati in anticipo a causa della forma delle lettere di "ACQUA".

Questa idea può essere ulteriormente ampliata, usando queste parole fatte di parole per creare parole fatte di parole fatte di parole , o anche parole fatte di parole fatte di parole fatte di parole . Non ci sono limiti teoricamente.

Un altro esempio metterebbe questo post oltre il limite di 30k caratteri, ma puoi vedere cosa si intende per "parole fatte di parole fatte di parole" eseguendo questo elegante frammento di stack. Lascia i parametri ai valori predefiniti e premi "Vai!". Dovresti vedere la parola "CANE" fatta della parola "CAT" fatta della parola "MOUSE".

La digitazione di un elenco di parole separato da spazi contenente solo lettere maiuscole nella casella di testo produrrà la prima parola fatta della seconda parola fatta della terza, fatta della quarta, fatta di ... ecc.

ATTENZIONE: l'immissione di più di 4 o anche 3 parole produrrà MOLTO testo e impiegherà molto tempo. Potrebbe causare l'arresto anomalo del browser / computer / auto.

Sfida

L'obiettivo di questa sfida è rispecchiare ciò che lo Stack Snippet fa nel minor numero di personaggi.

È necessario scrivere un programma che includa una stringa di parole separata da spazi contenente solo lettere maiuscole e che generi la prima parola "fatta di" la seconda "fatta di" la terza e così via, usando il carattere pixelato sopra indicato.

La casella di controllo "ASCII normale" e le caratteristiche della dimensione del carattere dello snippet non devono essere supportate nel programma. Il mirroring della trasformazione da elenchi di parole a parole fatte di parole è il punto principale e l'unico requisito.

Dettagli

  • L'input dovrebbe provenire da stdin, dalla riga di comando, oppure potresti semplicemente scrivere una funzione che accetta una stringa.

  • Puoi supporre che l'input sia sempre valido, cioè una stringa di parole fatta di lettere maiuscole, separate da esattamente uno spazio, senza spazi iniziali o finali.

  • L'output dovrebbe andare su stdout (o alternativa simile) o su un file con il nome che preferisci.

  • L'uscita dovrebbe consistere interamente di caratteri vuoto-spazio , caratteri interi spazio e ritorni a capo.

    • I caratteri vuoto / spazio intero devono essere rispettivamente spazio e blocco completo ( , ) oppure punto e X ( ., X) rispettivamente.
  • L'output non deve contenere colonne iniziali contenenti solo caratteri di spazio vuoto , sebbene sia consentita qualsiasi combinazione di caratteri di spazio vuoto finali su qualsiasi riga.

    • Quindi questo è permesso:

      X...X.XXXXX..
      X...X.X
      X.X.X.XXXX....
      X.X.X.X..
      .X.X..XXXXX..
      
    • Ma questo non è:

      .X...X.XXXXX..
      .X...X.X
      .X.X.X.XXXX....
      .X.X.X.X..
      ..X.X..XXXXX..
      
  • Non ci dovrebbero essere righe iniziali o finali contenenti solo caratteri di spazio vuoto . È consentita una singola riga finale finale.

Ecco una versione più amichevole del carattere:

.XXX.
X...X
XXXXX
X...X
X...X

XXXX.
X...X
XXXX.
X...X
XXXX.

.XXX.
X...X
X....
X...X
.XXX.

XXXX.
X...X
X...X
X...X
XXXX.

XXXXX
X....
XXXX.
X....
XXXXX

XXXXX
X....
XXXX.
X....
X....

.XXXX
X....
X..XX
X...X
.XXXX

X...X
X...X
XXXXX
X...X
X...X

XXXXX
..X..
..X..
..X..
XXXXX

....X
....X
....X
X...X
.XXX.

X...X
X..X.
XXX..
X..X.
X...X

X....
X....
X....
X....
XXXXX

X...X
XX.XX
X.X.X
X...X
X...X

X...X
XX..X
X.X.X
X..XX
X...X

.XXX.
X...X
X...X
X...X
.XXX.

XXXX.
X...X
XXXX.
X....
X....

.XXX.
X...X
X...X
X..XX
.XXXX

XXXX.
X...X
XXXX.
X..X.
X...X

.XXXX
X....
.XXX.
....X
XXXX.

XXXXX
..X..
..X..
..X..
..X..

X...X
X...X
X...X
X...X
.XXX.

X...X
X...X
.X.X.
.X.X.
..X..

X...X
X...X
X.X.X
X.X.X
.X.X.

X...X
.X.X.
..X..
.X.X.
X...X

X...X
.X.X.
..X..
..X..
..X..

XXXXX
...X.
..X..
.X...
XXXXX

punteggio

Questo è quindi vince l' invio più breve in byte . Qualsiasi istanza di un blocco completo ( ) può essere conteggiata come 1 byte anziché 3, quindi gli invii che utilizzano Xnon hanno alcun vantaggio.


5
È possibile eseguire il seguente frammento di codice JavaScript (ad esempio digitando. javascript:Nella barra degli indirizzi e incollandolo) per rendere l'arte ASCII qui molto, molto più facile da leggere: $('#question pre').css('line-height',1). Risultato: i.stack.imgur.com/XmB8C.png
Maniglia della porta

1
O per includere le risposte$('#question pre, .answer pre').css('line-height',1)
Martin Ender,

So che è un po 'troppo tardi per fare questa battuta, ma non ho resistito: i.imgur.com/vAZi1Zt.png .
algoritmo

Come ho perso questa sfida ?!
Magic Octopus Urn,

Risposte:


8

CJam, 171 165 162 161 byte

qS/_0=,0a*a\{{W:I;{'[{RI):I=}?i65-"c¿»ÐòO*4Õ]%ÐÎ<à IX]{-ïèq=ô}s×o)½2~û³'é¨1ÃlØeúN!Ö3~4ÜË|ÕÇäaepý®"255b2b5/5/=}%z1af*}%R,1a*a*}fR2a*"█ 
"f=

Sto trattando come 1 byte. Riposare tutti i caratteri rientrano nell'intervallo ASCII, quindi trattandoli anche come 1 byte.

Puoi usare questo pastebin per il codice esatto

Esempio di output per input:

FIRST HELLO WORLD

inserisci qui la descrizione dell'immagine

Come funziona

Prima di tutto

"c¿»ÐòO*4Õ]%ÐÎ<à IX]{-ïèq=ô}s×o)½2~û³'é¨1ÃlØeúN!Ö3~4ÜË|ÕÇäaepý®"255b2b5/5/

è semplicemente il modello per ciascuno dei 27 caratteri ( A-Ze spazio) composto da 0(in Xposizioni) e 1(in .posizioni). Dopo la decodifica, questo fornisce un array di 27 elementi di array 2D di 5 righe e 5 colonne che rappresentano Xe .per ciascuno dei 27 caratteri. Chiamiamo questo array come L.

Ora il codice rimanente:

qS/                      "Read the input and split it on space to get array Q";
   _0=                   "Get a copy of the first element of the above array";
      ,0a*               "Create an array filled with 0 with length of the first element";
          a\             "Wrap that array in another array and swap to get Q on top";
{  ...  }fR              "This is a for each loop on the array Q with R having the";
                         "current element value in each loop";
 {...}%                  "In the first iteration, the 0 array we created will be the";
                         "only thing on stack, in subsequent iterations, the result";
                         "of previous iteration will be on stack";
  W:I;                   "Initialize variable I with -1";
      {...}%             "Run this block on each element of the current array";
{'[{RI):I=}?i65-L=}%     "This is the above code block. In each iteration, we figure";
                         "out what character needs to be be put at the current index";
                         "Then we get the pattern of 0 and 1 for that character";
 '[{      }?             "Stack contains either 0 or 1. If it is 1, we want to leave";
                         "that index blank, so we put pattern of '[ which is 5X5 spaces";
    RI_:I=               "When we do not want a blank character, we get the next"
                         "character from R to fill the non empty space";
            i65-         "Convert A-Z  to 0-27 notation";
                L=       "Get the corresponding pattern from the pattern array L";
z1af*                    "After the above iterations, for each line of the previous";
                         "iteration's output, we get a vertical 2D array for next";
                         "iteration. We transpose it and join each character in";
                         "this line using a space";
      R,1a*a*            "After getting all lines from current iteration, we join them";
                         "with one full line of space characters";

 2a*                     "After all iterations, we have the 0 1 based 2D array for the";
                         "final output ASCII with each row representing a line. We join";
                         "these lines with 2, to get a 0 1 2 based array";
     "█                  "A brick, a space and a newline. Mapping 1 to 1 with 0 1 2";
"                        "based array";
 f=                      "For each of the 0 1 2 based array element, convert them to";
                         "one of the brick, space and new line character";

Provalo online qui


9

Python 3, 437 byte

from numpy import*
s=input().split()
d=fromstring('NONO__^Q_PQAQQNONO^_QQQQQ_QQQQAAAQDPIA[SQQQQADQQQJJH_OAQOOY_DPGAUUQOQONDQJUDDDQQQQAAQQDQIAQYQAYIPDQJUJDBQONO_A^Q_NQ_QQNA^QODNDJQD_',byte)[:,None]>>arange(5)&1
b=0
x=1
y=len(s[0])
n=[[1]*y]
for w in s:
 g=n;b+=x;x*=6;n=zeros((x,x*y),int);i=-6
 for q in g:
  o=j=0;i+=6
  for p in q:n[i:i+5,j:j+5]|=d[ord(w[o%len(w)])-65::26]*p;o+=p;j+=6
for r in n[:-b]:print(''.join(' █'[x] for x in r))

Le forme dei caratteri sono codificate in ASCII. Ogni byte ASCII corrisponde a una riga di un carattere, con bit che rappresentano blocchi di unità. Non è uno schema molto efficiente, ma è facile scompattare nelle maschere di bit NumPy per ogni personaggio.

Iniziamo con un array 2d di 1s. Ha una colonna per ogni carattere nella prima parola e una singola riga. Quindi, per ogni parola, creiamo un nuovo array di 0, sei volte più alto e sei volte più ampio del precedente array. Se l'array precedente aveva un 1, la sezione 6x6 corrispondente del nuovo array viene riempita con la maschera di bit del personaggio appropriato.

Ecco un esempio (con un carattere estremamente piccolo):

inserisci qui la descrizione dell'immagine


5

CJam, 181 174 170 byte

Tutti quei caratteri non ASCII sono ancora all'interno dell'intervallo ASCII esteso, quindi possono essere tutti codificati in un singolo byte. (Ad eccezione di , ma quello viene trattato in modo speciale in base alle specifiche della sfida.) Pertanto, conto ogni personaggio come un byte.

"Á  :½A%õ­Íú£à˪ë8!Õ*j4¶fVËa¡ùÔ¯{+ÛyéâõKn#@?
9Ôia)(Ñç;~LÒª"257b2bYYb" █"er5/5/:L;lS/_0=,'█*a\{f{W:T;\{' ={S5*a5*}{T):T1$='A-L=}?\}%W<zSf*}Sa*}/N*

Stack Exchange ha probabilmente alterato alcuni dei caratteri non stampabili, quindi potresti dover copiare il codice da questo pastebin .

Provalo qui.

Accetta input tramite STDIN come un elenco di parole separato da spazi. La prima parola è la scala più grande. Per esempio:

HOLISM REDUCTIONISM

i rendimenti

████                    █████             ████  █   █  ███              █████                               █████  ███  █   █ █████  ████             █   █ ████  █████ ████        █   █                    ███ 
█   █                   █                 █   █ █   █ █   █               █                                   █   █   █ ██  █   █   █                 ██ ██ █   █ █     █   █       █   █                   █   █
████                    ████              █   █ █   █ █                   █                                   █   █   █ █ █ █   █    ███              █ █ █ ████  ████  █   █       █   █                   █    
█  █                    █                 █   █ █   █ █   █               █                                   █   █   █ █  ██   █       █             █   █ █  █  █     █   █       █   █                   █   █
█   █                   █████             ████   ███   ███                █                                 █████  ███  █   █ █████ ████              █   █ █   █ █████ ████         ███                     ███ 

████                    █████       ████                    █   █        ███                                            █████                   █████                                ███  █   █       █████  ████
█   █                   █           █   █                   █   █       █   █                                             █                       █                                 █   █ ██  █         █   █    
████                    ████        █   █                   █   █       █                                                 █                       █                                 █   █ █ █ █         █    ███ 
█  █                    █           █   █                   █   █       █   █                                             █                       █                                 █   █ █  ██         █       █
█   █                   █████       ████                     ███         ███                                              █                     █████                                ███  █   █       █████ ████ 

████  █████ ████  █   █  ███        █████                   █████        ███                                            █   █                         █████  ████ █   █             ████        █████       ████ 
█   █ █     █   █ █   █ █   █         █                       █         █   █                                           ██  █                           █   █     ██ ██             █   █       █           █   █
████  ████  █   █ █   █ █             █                       █         █   █                                           █ █ █                           █    ███  █ █ █             ████        ████        █   █
█  █  █     █   █ █   █ █   █         █                       █         █   █                                           █  ██                           █       █ █   █             █  █        █           █   █
█   █ █████ ████   ███   ███          █                     █████        ███                                            █   █                         █████ ████  █   █             █   █       █████       ████ 

████                    █████       ████                    █   █        ███                                            █████                                           █████        ███                    █   █
█   █                   █           █   █                   █   █       █   █                                             █                                               █         █   █                   ██  █
████                    ████        █   █                   █   █       █                                                 █                                               █         █   █                   █ █ █
█  █                    █           █   █                   █   █       █   █                                             █                                               █         █   █                   █  ██
█   █                   █████       ████                     ███         ███                                              █                                             █████        ███                    █   █

████                    █████             ████  █   █  ███              █████ █████  ███  █   █ █████        ████ █   █ ████  █████ ████        █   █  ███  █████ █████              ███                    █   █
█   █                   █                 █   █ █   █ █   █               █     █   █   █ ██  █   █         █     ██ ██ █   █ █     █   █       █   █ █   █   █     █               █   █                   ██  █
████                    ████              █   █ █   █ █                   █     █   █   █ █ █ █   █          ███  █ █ █ ████  ████  █   █       █   █ █       █     █               █   █                   █ █ █
█  █                    █                 █   █ █   █ █   █               █     █   █   █ █  ██   █             █ █   █ █  █  █     █   █       █   █ █   █   █     █               █   █                   █  ██
█   █                   █████             ████   ███   ███                █   █████  ███  █   █ █████       ████  █   █ █   █ █████ ████         ███   ███    █   █████              ███                    █   █

Spiegazione

Innanzitutto, memorizziamo una tabella di ricerca per le forme delle lettere in L:

"Á  :½A%õ­Íú£à˪ë8!Õ*j4¶fVËa¡ùÔ¯{+ÛyéâõKn#@?
9Ôia)(Ñç;~LÒª"257b2bYYb" █"er5/5/:L;

La prima stringa è solo un numero compresso. Trattiamo i punti di codice come cifre base-257, quindi convertiamo il numero risultante in binario. YYbè 2 è nella base 2, quindi dà [1 0]. Usiamo la sostituzione degli elementi con " █"per trasformare le cifre in spazi e bloccare i caratteri. Infine, abbiamo diviso la stringa in righe di 5 caratteri e di nuovo in blocchi di 5 righe. Il risultato viene archiviato Le scartato dallo stack.

Ora l'idea generale è di iniziare con una sola riga della lunghezza della parola su larga scala. E poi per ogni parola passiamo attraverso la griglia esistente ed espandiamo tutti i blocchi al carattere corrispondente alla scala più piccola successiva (mentre inseriamo righe e colonne vuote per la separazione). Ecco la preparazione dell'input:

lS/_0=,'█*a\
lS/          "Read input, split on spaces.";
   _0=       "Duplicate and get first word.";
      ,'█*   "Get length repeat █ that many times.";
          a  "Wrap in array, to make the grid two-dimensional.";
           \ "Swap with word list.";

Diamo un'occhiata prima alla struttura più esterna del programma rimanente. Il blocco successivo {...}/viene eseguito per ogni parola ed espande ciascuno dei caratteri del blocco.

{f{...}Sa*}/N*
{         }/   "Process each word in the input.";
 f{...}        "Map this block onto each line of the grid, passing in the current word as well.";
       Sa*     "Since each original line will be turned into 5 lines, the grid is still grouped
                into blocks of 5 lines. We join them together with empty lines as required.";
            N* "Join all lines together with newlines.";

Infine, diamo un'occhiata a come viene espansa una singola riga:

W:T;\{' ={S5*a5*}{T):T1$='A-L=}?\}%
W:T;                                "Store -1 in T.";
    \                               "Swap word with line.";
     {                           }% "Map this block onto each character.";
      ' =                           "Check if the character is a space.";
         {      }{            }?    "If it is, run the first block, otherwise the second.";
          S5*                       "Create a string of five spaces.";
             a5*                    "Create an array of five such strings.";
                  T):T              "Push T, increment, store in T.";
                      1$=           "Copy the word and access the T'th character, cyclically.";
                         'A-        "Subtract A from the letter.";
                            L=      "Use the result to get the character shape from L.";
                                \   "Swap resulting block with word.";

"At this point each character is replaced with a 5x5 array of new characters.
 So we actually have a 3D array right now. Since we used a map operation, the
 current word will also be at the end of the array, which we need to get rid off.";

W<zSf*
W<     "Discard last array element - the current word.";
  z    "Zip or transpose the top two levels of the array.";
   Sf* "Join each line together with spaces.";

Il risultato viene stampato automaticamente alla fine del programma.

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.