Construa uma multidão de rostos suspeitos felizes de Lenny (͡ ° ͜ʖ ͡ °)


25

Eu estava passando por um tópico bizarro no Reddit, e me deparei com isso:

(͡ ° (͡ ° ͜ʖ (͡ ° ͜ʖ ͡ °) ʖ ͡ °) ͡ °)

Representa um grupo de pessoas sorrindo um tanto desconfiado.

(No desafio abaixo, porém, os espaços à esquerda dos olhos direitos foram removidos de alguma forma enquanto eu escrevia o desafio. Observe as especificações).


Seu objetivo é criar um grupo de rostos sorridentes lenny nprofundamente com as seguintes regras:

  1. Na profundidade um, uma face completa ( ( ͡° ͜ʖ ͡°)) é mostrada.
  2. Na profundidade dois, são mostradas meias faces. No lado esquerdo, um pouco mais da metade da face ( ( ͡° ͜ʖ) é representada. À direita, porém, o lado direito é mostrado e a boca é omitida ( ʖ ͡°))
  3. Mais profundo, e apenas os lados da cabeça e dos olhos são mostrados ( ( ͡°e ͡°). Há um espaço entre o olho e o lado esquerdo da cabeça, mas, apesar das aparências, não há espaços no lado direito. O espaçamento é devido ao ͡caractere que mexe um pouco com as coisas.

Entrada:

  • n, mostrando quantas camadas de profundidade de faces serão exibidas.
  • nestará sempre no intervalo 0 <= n <= 500. Você não precisa lidar com nada fora desse intervalo.
  • npode ser compensado por 1, para que 0 signifique uma face em vez de nenhuma face. Você precisará lidar com -1, no entanto.

Saída:

  • Uma cadeia de caracteres, ou matriz de caracteres, ou qualquer coisa remotamente comparável (como uma lista de cadeias de caracteres únicos em Python / Javascript). Também pode ser impresso diretamente. Trailing espaço em branco é bom.

Você pode enviar um programa completo ou uma função.


Como é difícil ver quais personagens estão envolvidos, aqui está o Python:

>> [ord(c) for c in '( ͡° ͜ʖ ͡°)']
[40, 32, 865, 176, 32, 860, 662, 32, 865, 176, 41]

>> [ord(c) for c in '( ͡°( ͡°( ͡° ͜ʖ( ͡° ͜ʖ ͡°)ʖ ͡°)͡°)͡°)']
[40, 32, 865, 176, 40, 32, 865, 176, 40, 32, 865, 176, 32, 860, 662, 40, 32, 865, 176, 32, 860, 662, 32, 865, 176, 41, 662, 32, 865, 176, 41, 865, 176, 41, 865, 176, 41]

Casos de teste:

face_crowd(0)
''

face_crowd(1)
'( ͡° ͜ʖ ͡°)'

face_crowd(2)
'( ͡° ͜ʖ( ͡° ͜ʖ ͡°)ʖ ͡°)'

face_crowd(5)
'( ͡°( ͡°( ͡°( ͡° ͜ʖ( ͡° ͜ʖ ͡°)ʖ ͡°)͡°)͡°)͡°)'

face_crowd(10)
'( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡° ͜ʖ( ͡° ͜ʖ ͡°)ʖ ͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)'

face_crowd(500)
'( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡°( ͡° ͜ʖ( ͡° ͜ʖ ͡°)ʖ ͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)͡°)'

Aqui está uma implementação de referência recursiva extraordinariamente ingênua (postada no meu Github). Tentei mantê-lo o mais claro possível para maior clareza; mas há muita duplicação

Postei externamente porque queria envolvê-lo em um spoiler, caso as pessoas não quisessem ver uma referência, mas isso complica a cópia do código. Eu acho que realmente não é importante para o desafio, então não é grande coisa se der certo. Posso colá-lo aqui se for considerado importante.


Isso é código-golfe, então o menor número de bytes em cada idioma vence.


11
Parece ainda mais suspeito quando renderizado no TIO. : p
Arnauld

As especificações e os casos de teste parecem inconsistentes; a especificação possui um espaço no início da parte direita das últimas profundidades, enquanto os casos de teste não.
tjjfvi

@ Arnauld Oh uau. Ya, em todos os lugares parece mostrar um pouco diferente.
Carcigenicate


1
@Arnauld Eu amo edição de URL também: -͡-͜ʖ-͡
val diz Reinstate Monica

Respostas:


14

Haskell , 89 87 80 bytes

7 bytes de desconto graças ao xnor

(!!)$"":x:iterate(4#8)(7#6$x)
x="( ͡° ͜ʖ ͡°)"
(a#b)y=take a x++y++drop b x

Experimente online!

Para começar, atribuímos (͡ ° ͜ʖ ͡ °) a uma string xpor conveniência.

x="( ͡° ͜ʖ ͡°)"

Em seguida, criamos uma lista de respostas e a indexamos para encontrar a solução. Isso é feito codificando as duas primeiras respostas como os dois primeiros elementos da lista e iterando uma função que adiciona os 4 primeiros caracteres e os 4 últimos caracteres à frente e atrás da string na terceira resposta.

(!!)$"":x:iterate(4#8)(7#6$x)

Também temos a função especial (#)que adiciona uma quantidade especificada de (͡ ° ͜ʖ ͡ °) à frente e atrás de uma string:

(a#b)y=take a x++y++drop b x

8

JavaScript (ES6), 66 bytes

f=n=>n?"( ͡°"+(--n>1?f(n):" ͜ʖ"+(n?f(n)+"ʖ ":" "))+"͡°)":""

Experimente online!

Ou tente com o seguinte trecho para obter uma renderização melhor.

Comentado

No código a seguir, usamos o conjunto de caracteres "eEMN"(sobrancelha, olho, boca e nariz, respectivamente) para preservar a formatação.

f = n =>           // f is a recursive function taking the number n of remaining
                   // faces to draw
  n ?              // if n is greater than 0:
    "( eE" + (     //   append the left cheek + a space + the left eye
      --n > 1 ?    //   decrement n; if it's still greater than 1:
        f(n)       //     append the result of a recursive call
      :            //   else (n = 0 or 1):
        "MN" + (   //     append the mouth and the nose
          n ?      //     if n = 1:
            f(n)   //       append the result of a recursive call
            + "N " //       followed by the nose + a space
          :        //     else (n = 0):
            " "    //       append a space and stop recursion
        )          //
    )              //
    + "eE)"        //   append the right eye + the right cheek
  :                // else:
                   //   the special case n = 0 is reached only if the original
    ""             //   input is 0; just return an empty string


6

Excel, 85 bytes

=IF(A1>1,REPT("( ͡°",A1-1)&" ʖ( ͡° ͜ʖ ͡°)ʖ "&REPT("͡°)",A1-1),REPT("( ͡° ͜ʖ ͡°)",A1))

Solução ingênua para n>1. Segunda repetição necessária para lidar com o 0testcase.


Você precisa do último REPT?
Neil

O último REPTé necessário para lidar com o 0caso.
Wernisch

5

Retina 0.8.2 , 56 bytes

.+
$*< $&$*>
 >>
 >ʖ >
<(?=<? )
< ͜ʖ
<
( ͡°
>
͡°)

Experimente online! Explicação:

.+
$*< $&$*>

Gere as bochechas, mas use <s e >s porque (s e )s precisariam ser citados. Um espaço no meio termina entre o nariz e o olho esquerdo do homem do meio.

 >>
 >ʖ >

Se o homem do meio tiver um homem à esquerda, dê a ele um nariz e um espaço entre ele e o olho esquerdo.

<(?=<? )
< ͜ʖ

Adicione a boca e o nariz ao homem do meio e ao homem à sua direita, se houver. Não vemos o olho esquerdo do homem à sua direita, para que ele não precise de espaço, e demos ao homem do meio um espaço no primeiro estágio.

<
( ͡°

Corrija as bochechas certas e adicione os olhos certos.

>
͡°)

Fixe as bochechas esquerdas e adicione os olhos esquerdos.


1
@ Arnauld Ufa, demorei algum tempo, mas acho que consegui corrigi-lo por apenas um byte extra!
Neil


4

Informar 7 , 262 bytes

To say x:say "[Unicode 865][Unicode 176]".
To say y:say Unicode 860.
To say z:say Unicode 662.
To say p (N - number):say "( [x][p N minus 1][x])".
To say p (N - 2):say "( [x] [y][z][p 1][z][x])".
To say p (N - 1):say "( [x] [y][z] [x])".
To say p (N - 0):say "".

Isso tira vantagem da sobrecarga de função do Inform 7: a sobrecarga mais específica será executada e a função que aceita um número (qualquer número inteiro) como argumento é menos específica do que a função que usa o número dois (e apenas dois) como argumento .

Existem alguns bits repetidos de texto, como "([x]", que podem ser abstraídos como funções próprias - mas I7 é muito detalhado, definir uma nova função requer mais bytes do que isso economizaria! a nova função parece salvar bytes é para caracteres não ASCII, uma vez que a sintaxe para imprimi-los é ainda mais detalhada do que a sintaxe para definições de função.

Boilerplate para executar isso:

Foo is a room. When play begins: say p 7.

Substitua 7 por um número inteiro não negativo de sua escolha.


É bom ver uma resposta do Inform!
Solha

3

Stax , 42 bytes

ü/┐▐Φd¬•U►^τ∩█┴êZ3↔uº'µ3ó(▀◄Ü▒iÇÆ'[∞_¥▄>A√

Execute e depure

Eu acho que parece não funcionar no Firefox no Windows. Mas isso é apenas porque a fonte padrão FF para monoespaço é Courier, que parece não suportar esses modificadores unicode sofisticados ou qualquer outra coisa. Eu acho que.


3

C ++ (gcc) , 102 bytes

#include <string>
std::string f(int n){return n?"( ͡°"+(--n>1?f(n):" ͜ʖ"+(n?f(n)+"ʖ ":" "))+"͡°)":"";}

Experimente online!

Porta descarada da solução JavaScript da Arnauld.


1
Talvez você precise incluir #include <string> # 103
AZTECCO

Na verdade, obrigado por me lembrar :)
G. Sliepen



2

Java 7, 133 90 89 bytes

String f(int n){return--n<0?"":"( ͡°"+(n>1?f(n):" ͜ʖ"+(n>0?f(n)+"ʖ ":" "))+"͡°)";}

Porto de Resposta de JavaScript recursiva @ Arnauld , já que é mais curta que a minha primeira tentativa inicial usando um lambda Java 8+.

Experimente online.

Explicação:

String f(int n){               // Recursive method with integer parameter & String return-type
  return--n                    //  Decrease the input by 1 first
           <0?                 //  And if the input is now -1:
              ""               //   Return an empty string
             :                 //  Else:
             "( ͡°"             //   Return the left part of Lenny's face
             +(n>1?            //   And if the modified input is larger than 1:
                   f(n)        //    Append a recursive call with this now decreased input
                  :            //   Else (the input is here either 0 or 1):
                   " ͜ʖ"        //    Append Lenny's nose
                   +(n>0?      //    And if the input is larger than 0 (thus 1):
                         f(n)  //     Append a recursive call
                         +"ʖ " //     As well as the right part of its nose
                        :      //    Else (thus 0):
                         " "   //     Append a space instead
            ))+"͡°)";}          //   And also append the right part of Lenny's 



1

Carvão , 41 bytes

NθP⭆θ✂ʖ ͡°)⊗‹¹ι←⭆θ✂ʖ͜ °͡ (∧‹¹ι³

Experimente online! O deverbosifier tenta citar a segunda string por algum motivo, mas não parece ser necessário, mas aqui está a versão detalhada, se você desejar. Explicação:

Nθ

Insira o número de faces.

P⭆θ✂ʖ ͡°)⊗‹¹ι

Imprima os lados esquerdos das faces (à nossa direita, como as vemos). Estes consistem na stringʖ ͡°) repetida até duas vezes e, em seguida, a sequência sem os dois primeiros caracteres repetiu o número restante de vezes.

←⭆θ✂ʖ͜ °͡ (∧‹¹ι³

Imprima os lados direito das faces (à nossa esquerda, como as vemos). Eles consistem na string (invertida)ʖ͜ °͡ ( repetida até duas vezes e, em seguida, essa sequência sem os dois primeiros caracteres repetiu o número restante de vezes.

Os mais observadores dentre vocês terão notado que a face do meio tem o nariz gerado duas vezes, e é por isso que estou imprimindo de tal maneira que elas se sobrepõem.


1

Python 3 , 80 caracteres, 86 bytes

x='( ͡° ͜ʖ ͡°)'
n=3-1
print(x[:4]*(n-1)+x[:7]*(n!=0)+x+x[6:]*(n!=0)+x[8:]*(n-1))

Experimente online!

Para colocar a entrada, altere o 3 para a entrada que desejar, deixando o -1 sozinho.

Se alguém souber uma maneira melhor de fazer uma entrada que reduziria a contagem de caracteres, me avise.

Nada extravagante acontecendo aqui, apenas cortar fatias e abusar de booleanos

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.