21 Прически Апокалипсиса

16

21 Прически Апокалипсиса

При наличии списка чисел от 1 до 21 (или от 0 до 20) выведите «сшитый» чертеж следующих граней ( см. Правила для сшивания информации ):

     ___           ,,,           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-

Каждое уникальное лицо, указанное в новой строке (# - это целочисленный идентификатор лица):

     ___      
    (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

Лицо выглядит следующим образом:

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

Где hдинамическая апокалиптическая прическа и Sпотенциальная черта сшивания.


Примеры

Входные данные: [1,2,3,4,5]

Выход:

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

Входные данные: [1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21]

Выход:

     ___           ,,,           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-

Вход: ["Fraggle Rock"] / [22]/ [-21041024]/[22,23,24,25,26]

Выход: Nobody cares.


Входные данные: [1,1,1,1]

Выход:

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

правила

  • Предшествующий и завершающий переводы строк / пробелов / дефиса в порядке.
  • Лица могут появляться более одного раза на входе.
  • Если на входе указан недопустимый номер, возможно, у вас неопределенное поведение.
  • Шить:
    • Сшитые грани будут объединены одним дефисом в нижней (3-й) строке.
    • Все грани будут на одной линии (в отличие от первого рисунка).
  • Входные данные могут быть проиндексированы 0 или 1, где 20 - максимум для 0, 21 - для 1.
  • Это , побеждает наименьшее количество байтов.
Урна волшебного осьминога
источник
1
Очень похоже: codegolf.stackexchange.com/q/34773/29750
NinjaBearMonkey
7
Номер 7, кажется, нарушает часть "лицо таково"
бобоквэк
10
Все ваши тесты включают в себя завершающий «сшиваемый» дефис, который, кажется, противоречит спецификации.
Shaggy
3
Килрой был здесь.
msh210
2
@MagicOctupusUrn, не могли бы вы рассмотреть вопрос о конечных дефисах, которые я поднял выше?
Лохматый

Ответы:

9

Japt -R , 122 117 113 110 109 107 105 104 103 102 100 99 байт

1-индексированный, с индексным переносом. Я следовал спецификации здесь, которая требует дефис между последней строкой каждого лица, а не тестовые случаи, которые включают дефис после последней строки каждого лица.

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

Попытайся

[                                             :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
Отличная работа - получить 100. Тот метод с зеркальным отражением, который мы хотели, действительно пригодился бы здесь.
Оливер
Кроме того, что обертывание, &чтобы воспользоваться было гением. Тем более, что это сделало это на 1 основе.
Оливер
Это было наоборот »; Я понял, что мог бы переехать &туда, если бы сделал это на основе 1;) Все еще чувствую, что здесь есть еще кое-что для гольфа, но уже поздно, поэтому придется подождать до завтра.
лохматый
6

Python 2 , 209 байт

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]

Попробуйте онлайн!

Индексирование на основе 0; ничего особенно умного здесь, только данные, доступные через разрезание и использование exec вместо цикла.

Час Браун
источник
186 байт
Линн,
6

Древесный уголь , 103 102 байта

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

Попробуйте онлайн! Ссылка на подробную версию кода. Объяснение:

E²⪫Eθ

Зациклите вход дважды. Каждый результат затем неявно печатается в отдельной строке.

⎇ι(o o)

Во втором цикле просто создайте глаза.

⪫ײ§ -⁼λ⁶

Завернуть прическу 6 в -с, остальные прически в прыщах.

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

Извлеките три символа прически из сжатой строки.

× ⁹

Вставьте девять пробелов между волосами или глазами.

M⁴←

Переместите 4 пробела влево.

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

Распечатайте остальные лица, соединенные с -.

Нил
источник
6

R , 413 391 байт

Спасибо Джузеппе за 22 байта меньше и получая это под 400 байтов.

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)]))}

Попробуйте онлайн!

Jayce
источник
Вы должны, вероятно, псевдоним utf8ToIntиintToUtf8
Джузеппе
391 байт
Джузеппе
@ Джузеппе хороший момент! Мне стыдно за свои индексные свопы, это так дорого. Я буду работать над этим.
JayCe
@JayCe Вы пропустили еще один, repчтобы сократить:for(i in s)K(I(c(rep<--
Кирилл Л.
Спасибо @KirillL. ! Я обязательно включу это, когда у меня наконец появится время пересмотреть этот код.
JayCe
5

JavaScript (ES6), 200 199 байт

Ожидается 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`
`

Попробуйте онлайн!

комментарии

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
Arnauld
источник
4

Рубин , 164 байта

->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}

Ноль индексируется. Попробуйте онлайн!

Все сложные вещи происходят в верхней строке.

"_,o=+# *| )(x ^ &"содержит все прически с 3 одинаковыми символами, из которых мы выбираем iсимвол,j .

Если jэто не пробел, следующее выражение возвращает 3 копии символа. Если это пробел, мы выбираем правильную прическу между %w{}. «Странные» прически имеют номера 6,9,13,14,15,16,18,19 и i%11-2дают идеальный хэш0..7

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

Все, что остается, - это заполнить 14 пробелов (по центру) и напечатать соответствующее количество середин / оснований.

Уровень реки St
источник
Вы можете оставить скобки вcenter(14)
Кирилл Л.
2

Java 8, 273 263 байта

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);}

Попробуйте онлайн.

Объяснение:

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 байт

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<
'*`
^^^
)|(
\|/
&&&

Попробуйте онлайн!

Теперь пытаемся привести R к более управляемому количеству байтов ...

Поскольку манипулирование персонажами в R настолько безнадежно многословно, я остановился на том, чтобы перечислить все образцы лица и прически как есть. Для красивой печати причесок я использую formatфункцию с justify="centre". К сожалению, нам нужно использовать дополнительный символ заполнения, i==20потому что formatвычисляет заполнение так, как будто экранированный обратный слеш экранирован, как \\|/.

Текущая версия не использует конечный дефис.

Изменить: Кредит для JayCe за -2 и Джузеппе за -3 байта.

Кирилл Л.
источник
Люблю ваш прямой подход! Я не знал о том, justify="centre"что, возможно, смогу снова его использовать. Минус два"/"=rep
символа
еще два байта вниз:format(h[i],,,,"c",14+!20-i)
Джузеппе
@Giuseppe это на самом деле -3, так что даже лучше. @JayCe очень хорошо, на самом деле мы тоже не используем умножение, поэтому переопределение *выглядит еще лучше - теперь это похоже на string * numberоперацию, характерную для многих других языков!
Кирилл Л.
2

C! ( C-Wow 1.1.0), 251 байт

(Требуется передать аргументы при выполнении программы, разделенные пробелом)

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)));

Безголовая версия:

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)));
0x22fe
источник
1

Красный , 333 319 байт

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]

Попробуйте онлайн!

Гален Иванов
источник
1

Рубин , 163 байта

->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}

Попробуйте онлайн!

0 индексированные. Я возился с ответом Level River St и нашел другой подход для кодирования причесок, по-видимому, похожего на гольфистость. Здесь мы рассматриваем «самую длинную» 5-символьную стрижку как особый случай, тривиальные шаблоны в первой части списка кодируются по 1 символу каждый, а во второй части все 3-символьные шаблоны перечислены буквально, независимо от того, эти символы различны или нет. Наконец прибывает шаблон обезьяны лица.

Кирилл Л.
источник
1

C (gcc) , 210 212 байтов

-4 байта благодаря потолку . (Он снова вырос, когда я исправил ошибку, которая была в исходном коде.)

Довольно просто.

#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-")}

Попробуйте онлайн!

gastropner
источник
206 байт
floorcat
1

PowerShell , 187 171 байт

-16 байт благодаря маззи

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

Попробуйте онлайн!

0-индексированный, имеет конечный дефис.

раскатали:

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

Ничего особенного. Только в первой строке есть приличная логика. Он индексирует в строку волос с помощью $current_entry_value*3и sудаляет этот кусок с помощью убстринаg , прежде чем объединить все куски в одну большую строку. Я столкнулся с проблемой «выхода из следующей каретки», и мне стало интересно, почему я получаю ошибку IndexOutOfBounds, но она исправлена. Теперь используем гораздо лучший способ объединить первую строку.

195 байт, чтобы следовать спецификации без начальных / конечных дефисов

Veskah
источник
1
приятно 7. Вы можете сохранить несколько байтов Попробуйте онлайн!
Маззи
1
и еще немного Попробуйте онлайн!
Мази
1

Python 3 , 240 байт

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)

Попробуйте онлайн!

Даниил Тутубалин
источник
0

Рунические чары , 313 байт

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-"

Попробуйте онлайн!

Разумно компактный с точки зрения сжатия строк и повторного использования сегментов, где это возможно, а также использования входных значений в качестве прямых смещений прыжка при Bранчо.

Если допускается избыточное конечное пространство, его можно сократить на 2 байта, пропустив 4-в последней строке. +2 байта для a, 1-если -предполагается, что финала не будет (соответствие спецификации, нарушение примеров).

Кусок, " (o o) " раздражающий, невозможно сжать, так как конструирование его с использованием таких вещей, как" "4* получается одинаковое количество байтов.

Проходные входы> 21 делают забавные вещи. Например, один 22 дает бритье .

Draco18s больше не доверяет SE
источник