Os 21 penteados do apocalipse


16

Os 21 penteados do apocalipse

Dada uma lista de números entre 1 e 21 (ou 0 e 20) produz um desenho "costurado" das seguintes faces ( consulte as regras para obter informações sobre costura ):

     ___           ,,,           ooo           ===           +++           ###          -*~*-     
    (o o)         (o o)         (o o)         (o o)         (o o)         (o o)         (o o)     
ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-

     ***           |||           _/7           )))           (((           xxx           @__      
    (o o)         (o o)         (o o)         (o o)         (o o)         (o o)         (o o)     
ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-

     ((_           >X<           '*`           ^^^           )|(           \|/           &&&      
    (o o)         (o o)         (o o)         (o o)         (o o)         (o o)         (o o)     
ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-

Cada face exclusiva listada em uma nova linha (o # é o ID inteiro da face):

     ___      
    (o o)     
ooO--(_)--Ooo #1

     ,,,      
    (o o)     
ooO--(_)--Ooo #2

     ooo      
    (o o)     
ooO--(_)--Ooo #3

     ===      
    (o o)     
ooO--(_)--Ooo #4

     +++      
    (o o)     
ooO--(_)--Ooo #5

     ###      
    (o o)     
ooO--(_)--Ooo #6

    -*~*-     
    (o o)     
ooO--(_)--Ooo #7

     ***      
    (o o)     
ooO--(_)--Ooo #8

     |||      
    (o o)     
ooO--(_)--Ooo #9

     _/7      
    (o o)     
ooO--(_)--Ooo #10

     )))      
    (o o)     
ooO--(_)--Ooo #11

     (((      
    (o o)     
ooO--(_)--Ooo #12

     xxx      
    (o o)     
ooO--(_)--Ooo #13

     @__      
    (o o)     
ooO--(_)--Ooo #14

     ((_      
    (o o)     
ooO--(_)--Ooo #15

     >X<      
    (o o)     
ooO--(_)--Ooo #16

     '*`      
    (o o)     
ooO--(_)--Ooo #17

     ^^^      
    (o o)     
ooO--(_)--Ooo #18

     )|(      
    (o o)     
ooO--(_)--Ooo #19

     \|/      
    (o o)     
ooO--(_)--Ooo #20

     &&&      
    (o o)     
ooO--(_)--Ooo #21

O rosto é o seguinte:

    hhhhh     
    (o o)     
ooO--(_)--OooS

Onde hestá o penteado apocalíptico dinâmico e So potencial hífen de costura.


Exemplos

Entrada: [1,2,3,4,5]

Resultado:

     ___           ,,,           ooo           ===           +++      
    (o o)         (o o)         (o o)         (o o)         (o o)     
ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-

Entrada: [1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21]

Resultado:

     ___           ,,,           ooo           ===           +++           ###          -*~*-          ***           |||           _/7           )))           (((           xxx           @__           ((_           >X<           '*`           ^^^           )|(           \|/           &&&      
    (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)         (o o)         (o o)         (o o)     
ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-

Entrada: ["Fraggle Rock"] / [22]/ [-21041024]/[22,23,24,25,26]

Resultado: Nobody cares.


Entrada: [1,1,1,1]

Resultado:

     ___           ___           ___           ___      
    (o o)         (o o)         (o o)         (o o)     
ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-ooO--(_)--Ooo-

Regras

  • Novas linhas / espaços / hífens anteriores e anteriores são bons.
  • Os rostos podem ocorrer mais de uma vez na entrada.
  • Se houver um número inválido na entrada, você poderá ter um comportamento indefinido.
  • A costura:
    • As faces costuradas serão concatenadas por um único hífen na linha inferior (3ª).
    • As faces estarão todas em uma única linha (diferente do primeiro desenho).
  • A entrada pode ser 0 ou 1 indexada, com 20 sendo o máximo para 0, 21 para 1.
  • Isso é , vitórias mais baixas na contagem de bytes.


7
Número 7 parece violar a "cara é a seguinte" parte
boboquack

10
Todos os seus casos de teste incluem um hífen de "costura" à direita, que parece contradizer as especificações.
Shaggy

3
Kilroy esteve aqui.
Msh210 11/1118

2
@MagicOctupusUrn, você pode abordar a questão dos hífens finais que levantei acima?
Shaggy

Respostas:


9

Japt -R , 122 117 113 110 109 107 105 104 103 102 100 99 bytes

1 indexado, com quebra de índice. Segui a especificação aqui, que requer um hífen entre a última linha de cada face, em vez dos casos de teste, que incluem um hífen após a última linha de cada face.

[Umg"@__((_>X<'*`^^^)|(\\|/"i"&_,o=+#*|)(x"m³ ò3 i7"-*~"ê)iA"_/7")¡"(o o)"á"O--(_)--O"ûoDÃq-]ûD m¸

Tente

[                                             :Construct an array of 3 elements
Umg"@.../"i"&...x"m³ ò3 i7"-*~"ê)iA"_/7")     :FIRST ELEMENT (F)
U                                             :  Input array
 m                                            :  Map
  g                                           :    Index into
   "@.../"                                    :      Literal string
          i                                   :      Prepend
           "&...x"                            :        Literal string
                  m                           :        Map
                   ³                          :          Repeat 3 times
                     ò3                       :      Split into chucks of 3
                        i7                    :      Insert at 0-based index 7
                          "-*~"ê              :        "-*~" palindromised
                                )             :      End insert
                                 iA"_/7"      :      Insert "_/7" at index 10
                                        )     :  End map
¡"(o o)"Ã                                     :SECOND ELEMENT (S)
¡                                             :  Map input array
 "(o o)"                                      :    Literal string
        Ã                                     :  End map
¡"O...O"ûoDÃq-                                :THIRD ELEMENT (T)
¡                                             :  Map input array
 "O...O"                                      :    Literal string
        ûo                                    :    Centre pad with "o"
          D                                   :      To length 13
           Ã                                  :  End map
            q-                                :  Join with "-"
]                                             :End array
 ûD                                           :Centre pad each string in F & S to length 13 with spaces, does nothing to T as it will always be at least 13 characters long
    m                                         :Map
     ¸                                        :  Join F & S with spaces. Split T on spaces, creating a singleton array which gets cast back to a string on output
                                              :Implicit output, joined with newlines

1
Bom trabalho, chegando a 100. Esse método de char-mirror que desejávamos seria realmente útil aqui.
1055 Oliver Oliver

Além disso, esse empacotamento do &que aproveitar era genial. Especialmente porque isso o tornou baseado em 1.
1013 Oliver Oliver

Era o contrário; Percebi que poderia mudar o &local se o fizesse com base em 1;) Ainda sinto que há mais para jogar aqui, mas é tarde, então terá que esperar até amanhã.
Salsicha

6

Python 2 , 209 bytes

def f(a):s=t=u='\n';i=0;exec"s+=(\"_,o=+#-*|_)(x@(>'^)\\&_,o=+#**|/)(x_(X*^||&_,o=+#~*|7)(x__<`^(/&\"[a[i]::21]+'*-'*(a[i]==6)).center(14);t+='    (o o)     ';u+='ooO--(_)--Ooo-';i+=1;"*len(a);print s+t+u[:-1]

Experimente online!

Indexação baseada em 0; nada de especialmente inteligente aqui, apenas dados acessados ​​via fatiamento e usando exec em vez de um loop.



6

Carvão , 103 102 bytes

E²⪫Eθ⎇ι(o o)⪫ײ§ -⁼λ⁶§⪪”|″:αuxkτT↷K[ï�↔ς↨?◧BZ@C←↑⊞A⧴M✂↶ºKf÷H#S⦃J&≔⁰∧5À³≕r‹▷”³λ× ⁹M⁴←⪫EθooO--(_)--Ooo¦-

Experimente online! Link é a versão detalhada do código. Explicação:

E²⪫Eθ

Faça um loop sobre a entrada duas vezes. Cada resultado é impresso implicitamente em sua própria linha.

⎇ι(o o)

No segundo loop, apenas gere os olhos.

⪫ײ§ -⁼λ⁶

Enrole o penteado 6 em -s, outros penteados nos espaços.

§⪪”|″:αuxkτT↷K[ï�↔ς↨?◧BZ@C←↑⊞A⧴M✂↶ºKf÷H#S⦃J&≔⁰∧5À³≕r‹▷”³λ

Extraia os três caracteres de penteado de uma sequência compactada.

× ⁹

Insira nove espaços entre cada cabelo ou olhos.

M⁴←

Mova 4 espaços para a esquerda.

⪫EθooO--(_)--Ooo¦-

Imprima o restante dos rostos unidos a um -.


6

R , 413 391 bytes

Obrigado Giuseppe por 22 menos bytes e obtendo isso abaixo de 400 bytes.

function(s,n=length(s)){I=intToUtf8
U=utf8ToInt
R=rep
K=cat
a=U("_,o=+#^*|&)(x")
b=c("@__","((_",">X<","'*`","",")|(","\\|/","","-*~*-","_/7")
s[s==7]=22;s[s==10]=23;s[s==18]=7;s[s==21]=10
for(i in s)K(I(c(rep(32,4+(i!=22)),"if"(i<14,R(a[i],3),U(b[i-13])),R(32,5+(i!=22)))))
K("
",I(R(c(R(32,3),40,111,32,111,41,R(32,6)),n)),"
")
K(I(40+R(c(x<-c(71,71,39,5,5),0,55,1,rev(x),5),n)[-(14*n)]))}

Experimente online!


você provavelmente deveria usar o apelido utf8ToInteintToUtf8
Giuseppe


@Giuseppe good point! Tenho vergonha dos meus swaps de índice, é tão caro. Vou trabalhar nisso.
21418 JayCe

@JayCe Você perdeu mais um reppara encurtar: #for(i in s)K(I(c(rep<--
Kirill L.

Obrigado @KirillL. ! Vou incluir isso quando finalmente tiver tempo para revisar este código.
Jayce

5

JavaScript (ES6), 200 199 bytes

Espera entrada indexada em 1.

a=>[1,0,2].map(y=>a.map(n=>s=y&2?'ooO--(_)--Ooo':`    ${p='( -'[y*n-7?y:2]}${"o o___,,,ooo===+++###*~****|||_/7)))(((xxx@__((_>X<'*`^^^)|(\\|/&&&".substr(y*n*3,3)}${y?p:')'}    `).join(s[3])).join`
`

Experimente online!

Comentado

a =>                              // given the input array a[]
  [1, 0, 2].map(y =>              // for each row y:
    a.map(n =>                    //   for each integer n in a[]:
      s =                         //     let s be the content of this row
        y & 2 ?                   //     if this is the 3rd row:
          'ooO--(_)--Ooo'         //       use a hardcoded string
        :                         //     else:
          `    ${                 //       append 4 spaces
            p = '( -'[            //       append and save in p:
              y * n - 7 ? y : 2   //         '(' if y = 0 (2nd row)
            ]                     //         ' ' if y = 1 and n != 7
          }${                     //         '-' if y = 1 and n = 7
            "o o___,,,ooo(...)"   //       append the middle pattern (NB: truncated string)
            .substr(y * n * 3, 3) //       which is always the eyes if y = 0
          }${                     //
            y ? p : ')'           //       append p for the 1st row or ')' for the 2nd row
          }    `                  //       append 4 spaces
    ).join(s[3])                  //   join with the 4th character of s (space or hyphen)
  ).join`\n`                      // join with line-feeds

4

Ruby , 164 bytes

->a{puts a.map{|i|j="_,o=+# *| )(x    ^  &"[i];(j<?!?%w{@__ ((_ >X< '*` -*~*- )|( \|/ _/7}[i%11-2]:j*3).center(14)}*"","    (o o)     "*k=a.size,"ooO--(_)--Ooo-"*k}

Zero indexado. Experimente online!

Todas as coisas difíceis acontecem na linha superior.

"_,o=+# *| )(x ^ &"contém todos os penteados com 3 caracteres idênticos, dos quais selecionamos o icaractere th j.

se jnão for um espaço, a expressão a seguir retornará 3 cópias do caractere. Se for um espaço, selecionamos o penteado correto entre os %w{}. Os penteados "ímpares" são os números 6,9,13,14,15,16,18,19 e i%11-2fornecem um hash perfeito para0..7

j<?!?%w{@__ ((_ >X< '*` -*~*- )|( \|/ _/7}[i%11-2]:j*3

Tudo o que resta é preencher 14 espaços (centralizados) e imprimir um número apropriado de meios / fundos.


Você pode colocar parênteses emcenter(14)
Kirill L.

2

Python 2 , 204 bytes

i=input();l=len(i)
for l in[' '*4+' -'[x==6]+"_,o=+#**|_)(x@(>'^)\\&_,o=+#~*|/)(x_(X*^||&_,o=+#**|7)(x__<`^(/&"[x::21]+' -'[x==6]+' '*5for x in i],['    (o o)     ']*l,['ooO--(_)--Ooo-']*l:print''.join(l)

Experimente online!


2

Java 8, 273 263 bytes

a->{String r[]={"","",""},s="    ",t="ooO--(_)--Ooo",u="(o o)";for(int i:a){r[0]+=s+(i==7?"-":" ")+"___,,,ooo===+++###*~****|||_/7)))(((xxx@__((_>X<'*`^^^)|(\\|/&&&".split("(?<=\\G...)")[i]+(i==7?"-":" ")+s+" ";r[1]+=s+u+s+" ";r[2]+=t+"-";}return t.join("\n",r);}

Experimente online.

Explicação:

a->{                       // Method with integer-array parameter and String return-type
  String r[]={"","",""},   //  Result-String, starting at three empty rows
         s="    ",         //  Temp-String of four spaces for the first and second rows
         t="ooO--(_)--Ooo",//  Temp-String for the third row
         u="(o o)";        //  Temp-String for the second row
  for(int i:a){            //  Loop over the input-array
    r[0]+=                 //   Append to the first row:
          s                //    Four spaces
          +(i==7?          //    If the number is 7 (edge-case):
             "-"           //     Append "-"
            :              //    Else:
             " ")          //     Append a single space
          +"___,,,ooo===+++###*~****|||_/7)))(((xxx@__((_>X<'*`^^^)|(\\|/&&&".split("(?<=\\G...)")[i]
                           //    Append the correct hat based on `i`
          +(i==7?"-":" ")  //    If the number is 7, append "-" again, else a space
          +s+" ";          //    And append five spaces
    r[1]+=                 //   Append to the second row:
          s                //    Four spaces
          +u               //    The head
          +s+" ";          //    Five spaces
    r[2]+=                 //   Append to the third row:
          t                //    The hands and bodies
          +"-";}           //    And the stitch "-"
  return t.join("\n",r);}  //  Return the three rows as single newline delimited String

2

R , 247 242 bytes

function(a,n=length(a)){for(i in a)cat(format(h[i],,,,"c",14+!20-i))
cat("
","   (o o)     "*n,"
")
cat("ooO--(_)--Ooo"*n,sep="-")}
"*"=rep
h=readLines(,21)
___
,,,
ooo
===
+++
###
-*~*-
***
|||
_/7
)))
(((
xxx
@__
((_
>X<
'*`
^^^
)|(
\|/
&&&

Experimente online!

Agora, tentando elevar R a uma contagem de bytes mais gerenciável ...

Como fazer manipulações de personagens em R é tão irremediavelmente detalhada, decidi listar todos os padrões de rosto e penteado completamente. Para imprimir bem os penteados com os quais uso a formatfunção justify="centre". Infelizmente, precisamos usar um caractere de preenchimento extra, i==20pois formatcalcula o preenchimento como se a barra invertida tivesse escapado, como \\|/.

A versão atual não usa hífen à direita.

Edit: Crédito para JayCe por -2 e Giuseppe por -3 bytes.


Ame sua abordagem direta! Eu não sabia justify="centre"que provavelmente poderia reutilizá-lo. Menos dois caracteres :"/"=rep
JayCe

mais dois bytes inativos:format(h[i],,,,"c",14+!20-i)
Giuseppe

@ Giuseppe é realmente -3, então ainda melhor. @ JayCe muito bom, na verdade também não usamos multiplicação, então substituir *parece ainda melhor - agora se assemelha à string * numberoperação comum a muitos outros idiomas!
Kirill L.

2

C! ( C-Wow 1.1.0), 251 bytes

(Requer argumentos a serem transmitidos na execução do programa, separados por espaço)

SS("     (o o)     \nooO--(_)--Ooo-",'\n') SS("___A,,,AoooA===A+++A###A-*~*-A***A|||A_/7A)))A(((AxxxA@__A((_A>X<A'*`A^^^A)|(A\\|/A&&&",'A') F(MR("0",A(0),"23"),W("?");E) I(AC,W("     ");RI(TN(A(i))+2);W("     ")); WL I(AC,W(RI(0))); WL I(AC,W(RI(1)));

Versão não destruída:

STRSPLIT("     (o o)     \nooO--(_)--Ooo-", '\n')
STRSPLIT("___A,,,AoooA===A+++A###A-*~*-A***A|||A_/7A)))A(((AxxxA@__A((_A>X<A'*`A^^^A)|(A\\|/A&&&", 'A')
IF(MATHRANGE("0", ARGS(0), "23"), PRINT("?"); E)
LOOP(ARGC, PRINT("     "); READI(TONUM(ARGS(i)) + 2); PRINT("     "));
PRINTL
LOOP(ARGC, PRINT(READI(0)));
PRINTL
LOOP(ARGC, PRINT(READI(1)));

1

Vermelho , 333 319 bytes

func[x][h: copy[]i: 0
foreach[k l m]{___,,,ooo===+++###   ***|||_/7)))(((xxx@__((_>X<'*`^^^^^^)|(\|/&&&}[alter h
pad pad/left either 7 = i: i + 1["-*~*-"][rejoin[" "k l m" "]]9
14]foreach y x[prin h/(y)]print append/dup copy"^/"{    (o o)     }l: length? x
print take/part append/dup copy""{ooO--(_)--Ooo-}l 14 * l - 1]

Experimente online!


1

Ruby , 163 bytes

->a{puts a.map{|i|(i==6?"-*~*-":i<9?"_,o=+#~*|"[i]*3:"_/7)))(((xxx@__((_>X<'*`^^^)|(\\|/&&&"[3*i-27,3]).center 14}*"","    (o o)     "*k=a.size,"ooO--(_)--Ooo-"*k}

Experimente online!

Indexado a 0. Eu brinquei com a resposta de Level River St e encontrei outra abordagem para codificar os penteados, aparentemente com uma golfabilidade semelhante. Aqui, tratamos o corte de cabelo "mais longo" com 5 caracteres como um caso especial, os padrões triviais na primeira parte da lista são codificados por 1 caracter cada e, na segunda parte, todos os padrões de 3 caracteres são listados literalmente, não importa - esses caracteres são distintos ou não. Finalmente, vem o clichê de cara de macaco.


1

C (gcc) , 210 212 bytes

-4 bytes graças ao ceilingcat . (Ele cresceu novamente quando corrigi um bug que o código original tinha.)

Bem direto.

#define r(s)for(i=!puts("");i<n;printf(s,c,"___,,,ooo===+++###*~****|||_/7)))(((xxx@__((_>X<'*`^^^)|(\\|/&&&"+x*3,c=x^6?32:45,x=l[i++]));
x,c,i;f(l,n)int*l;{r("%5c%.3s%-6c")r("    (o o)     ")r("ooO--(_)--Ooo-")}

Experimente online!



1

PowerShell , 187 171 bytes

-16 bytes graças ao mazzy

''+($args|%{($x=' '*4)+($y=' -'[$_-eq6])+("___,,,ooo===+++###*~****|||_/7)))(((xxx@__((_>X<'*``^^^)|(\|/&&&"|% s*g($_*3)3)+$y+$x;$z++})
"$x(o o)$x "*$z
"ooO--(_)--Ooo-"*$z

Experimente online!

Indexado a 0, tem um hífen à direita.

Desenrolado:

''+($args|%{
    ($x=' '*4) + ($y=' -'[$_-eq6]) + 
    ("___,,,ooo===+++###*~****|||_/7)))(((xxx@__((_>X<'*``^^^)|(\|/&&&"|% substring ($_*3) 3) +
    "$y$x ";
    $z++
    })
"$x(o o) $x"*$z
"ooO--(_)--Ooo-"*$z

Nada muito chique. Somente a primeira linha possui uma lógica decente. Ele indexa na cadeia de cabelo usando o $current_entry_value*3e retira esse pedaço usando substring , antes de juntar todos os pedaços em uma linha grande. Corri para o problema de `escapar do próximo sinal de intercalação, deixando-me pensar por que estava recebendo um erro IndexOutOfBounds, mas isso foi corrigido. Agora, usando uma maneira muito melhor de combinar a primeira linha.

195 bytes para seguir as especificações de nenhum hífen inicial / final


1
bom 7. você pode economizar alguns bytes Experimente online!
Mazzy

1
e um pouco mais Experimente online!
Mazzy

1

Python 3 , 240 bytes

h=[x*3for x in"_,o=+#*|)(x^&"]
for i,*l in(6,"-*~*-"),(9,"_/7"),(13,"@__","((_",">X<","'*`"),(18,")|(","\|/"):h[:i]+=l
*x,=map(int,input().split())
l=len(x)
p=print
p(*(h[i].center(13)for i in x))
p("    (o o)     "*l)
p("ooO--(_)--Ooo-"*l)

Experimente online!


0

Encantos Rúnicos , 313 bytes

B6?>8b2*B0il2)?\B" "9a2*
{" ___ "D
{" ,,, "D
{" ooo "D
{" === "D
{" +++ "D
{" ### "D
{"-*~*-"D
{" *** "D
{" ||| "D
{" _/7 "D
{" ))) "D
{" ((( "D
{" xxx "D
{" @__ "D
{" ((_ "D
{" >X< "D
{" '*` "D
{" ^^^ "D
{" )|( "D
{" \|/ "D\
{" &&& "D{
{"    " LLRB͍!{
"-(_)--Ooo-"{*@\~4-:l͍e,:{$ak$"    (o o)     "{*$ak$"ooO-"

Experimente online!

Razoavelmente compacto em termos de compactação de strings e reutilização de segmentos, sempre que possível, além de usar os valores de entrada como compensações diretas de salto na Bpecuária.

Se o excesso de espaço à direita for permitido, isso poderá ser reduzido em 2 bytes, omitindo-o 4-na última linha. +2 bytes para a 1-se o final -não estiver lá (especificações correspondentes, exemplos violadores).

O pedaço " (o o) "é irritante e impossível de compactar, pois construí-lo usando coisas como " "4*acaba sendo exatamente o mesmo número de bytes.

Passar entradas> 21 faz coisas divertidas. Por exemplo, um único 22 faz a barba rente .

Ao utilizar nosso site, você reconhece que leu e compreendeu nossa Política de Cookies e nossa Política de Privacidade.
Licensed under cc by-sa 3.0 with attribution required.