Faça uma bandeira acenar


26

Pegue uma bandeira, como esta:

-----------------------------
|             |             |
|             |             |
|=============+=============|
|             |             |
|             |             |
-----------------------------

E uma entrada numérica: o "comprimento da onda"

Digamos que o comprimento da onda fosse 5. Em seguida, a cada 5 caracteres ao longo da linha desde o início, substitua o próximo caractere por -com \e mude todos os caracteres após uma linha para baixo. Repita isso até o fim. Você acaba com:

-----\
|     -----\
|           -----\
|=====        |   -----\
|     ======  |         -----
|           ==+===          |
-----\        |   ======    |
      -----\  |         ====|
            -----\          |
                  -----\    |
                        -----

Se você não conseguir fazer uma onda completa no final, a bandeira estará concluída. Apenas permaneça plano até o fim.

Você pode assumir que todas as linhas têm o mesmo comprimento e que as linhas superior e inferior são compostas inteiramente por -(0x2D) e o restante dos caracteres está dentro !"#$%&\'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~ou é um espaço ( ). (Portanto, o valor ASCII é xonde 31 < x < 127)
A bandeira terá pelo menos 3 de altura e 3 de largura.

O comprimento da onda será um número inteiro não negativo (> = 0).

(Você também pode ter o comprimento de onda 1 como o menor comprimento de onda, portanto o exemplo acima teria o comprimento de onda 6. Isso é bom.)

Seu sinal de E / S pode ser como matrizes de linhas ou uma string com várias linhas.

O sinalizador de saída pode ter espaços à direita, mas só pode ter espaços à esquerda, desde que seja o mesmo em todos os sinalizadores. O espaço à direita em um sinalizador de entrada pode ser excluído.

Pontuação

Isso é código-golfe, então a solução mais curta, em bytes, vence.

Casos de teste

---
abc
---
2
--\
abc
--\



-----
| + |
-----
10
-----
| + |
-----



---------------------------------------
|&&&&&&                         &&&&&&|
|&&&&&&                         &&&&&&|
|&&&&&&                         &&&&&&|
|&&&&&&          .\^/.          &&&&&&|
|&&&&&&        . |   | .        &&&&&&|
|&&&&&&        |\|   |/|        &&&&&&|
|&&&&&&     .--'       '--.     &&&&&&|
|&&&&&&      \           /      &&&&&&|
|&&&&&&       >         <       &&&&&&|
|&&&&&&      '~|/~~|~~\|~'      &&&&&&|
|&&&&&&            |            &&&&&&|
|&&&&&&                         &&&&&&|
|&&&&&&                         &&&&&&|
---------------------------------------
12
------------\                          
|&&&&&&      ------------\             
|&&&&&&                   ------------\
|&&&&&&                         &&&&&&|
|&&&&&&                         &&&&&&|
|&&&&&&          .\^/.          &&&&&&|
|&&&&&&        . |   | .        &&&&&&|
|&&&&&&     .  |\|   |/|        &&&&&&|
|&&&&&&      --'       '--      &&&&&&|
|&&&&&&      \           /.     &&&&&&|
|&&&&&&       >         <       &&&&&&|
|&&&&&&      '~|/~~|~~\|~'      &&&&&&|
|&&&&&&            |            &&&&&&|
|&&&&&&                         &&&&&&|
------------\                   &&&&&&|
             ------------\      &&&&&&|
                          ------------\



-----------------------
|-._`-._ :| |: _.-'_.-|
|   `-._`:| |:`_.-'   |
|-------`-' '-'-------|
|------_.-. .-._------|
|  _.-'_.:| |:._`-._  |
|-'_.-'  :| |:  `-._`-|
-----------------------
4
----\
|-._`----\
|   `-._ :----\
|-----._`:| |: ----\
|-------`-| |:`_.-'_---
|  _.--_.-' '-'_.-' .-|
|-'_.-'_.:. .-.-----  |
----\-'  :| |:._------|
     ----\| |: _`-._--|
          ----\ `-._  |
               ----\`-|
                    ---



---------------
---------------
---------------
---------------
---------------
5
-----\         
-----------\   
---------------
---------------
-----\---------
      -----\---
            ---



-------------------------------------------
|*  *  *  *  * |##########################|
| *  *  *  *  *|                          |
|*  *  *  *  * |##########################|
| *  *  *  *  *|                          |
|*  *  *  *  * |##########################|
| *  *  *  *  *|                          |
|*  *  *  *  * |##########################|
|---------------                          |
|#########################################|
|                                         |
|#########################################|
|                                         |
|#########################################|
-------------------------------------------
0
\
|\
|*\
|  \
|** \
|   *\
|**   \
|   ** \
|**    *\
|-  **   \
|#-    ** \
| #-**    *\
|# #-  **   \
| # #-    ** \
\# # #-**    *\
 \# # #-  **   \
  \# # #-    **|\
   \# # #-**   |#\
    \# # #-  **| #\
     \# # #-   |# #\
      \# # #-**| # #\
       \# # #- |# # #\
        \# # #-| # # #\
         \# # #-# # # #\
          \# # # # # # #\
           \# # # # # # #\
            \# # # # # # #\
             \# # # # # # #\
              \# # # # # # #\
               \# # # # # # #\
                \# # # # # # #\
                 \# # # # # # #\
                  \# # # # # # #\
                   \# # # # # # #\
                    \# # # # # # #\
                     \# # # # # # #\
                      \# # # # # # #\
                       \# # # # # # #\
                        \# # # # # # #\
                         \# # # # # # #\
                          \# # # # # # #\
                           \# # # # # # #\
                            \# # # # # # #\
                             \# # # # # # |
                              \# # # # # #|
                               \# # # # # |
                                \# # # # #|
                                 \# # # # |
                                  \# # # #|
                                   \# # # |
                                    \# # #|
                                     \# # |
                                      \# #|
                                       \# |
                                        \#|
                                         \|
                                          \

4
Esperando que o @LuisMendo venha aqui e exploda isso no dia seguinte.
Magic Octopus Urn

Merda ... Esqueceu @ não liga aqueles que não responderam ... Alguém chutou minha bunda usando MATL, por favor, para que eu possa excluir os comentários.
Magic Octopus Urn

2
Alguém animar isso
Matthew Roh

1
@SIGSEGV Feito , embora talvez não seja o que você tinha em mente.
Brian McCutchon

1
@carusocomputing Alguém me ligou? 31 bytes, no entanto
Luis Mendo

Respostas:


11

05AB1E , 25 23 26 25 bytes

-2 graças a Adnan

-1 graças a Emigna

+3 obrigado a Jonathan Allan (obrigado por dedicar seu tempo à captura dessa invalidez!)

øvyN>²Öi¦¨'\.ø}N²÷ú}).Bø»

Experimente online!

Isso é indexado em 1 em vez de 0, +2 bytes, se isso não estiver correto.

ø                                    # Transpose.
 vy                }                 # For each column...
   N>²Öi¦¨'\.ø}                      # Replace outside dashes with slants.
               N²÷                   # Current index / input #2.
                  ú                  # Prepend that many spaces to current column.
                    ).Bø             # Join, pad, transpose back.
                        »            # Print with newlines.

Emigna / Adnan / Anyone - Tem que haver uma solução melhor para substituir essas inclinações, mas estou perplexo.


A indexação 1 está OK.
Artyer 11/05/19

1
úé o mesmo que ð×ì:)
Adnan

1
@ Artyer não a todos! +3 obrigado por apontar que minha resposta não era válida. Gosto quando as pessoas realmente se importam o suficiente para ler uma resposta por tempo suficiente para perceber que não está correta. Eu reformulei o suficiente para parecer menos sarcástico: P?
Magic Octopus Urn

2
@Adnan NENHUMA MARAVILHA NUNCA POSSO RESPONDER A ELE. Desculpe por massacrar seu nome Jonathan Allan .
Magic Octopus Urn

2
Realmente não é um problema :)
Jonathan Allan


8

Python 2 , 129 bytes

lambda f,n,j=''.join:map(j,zip(*[i/n*' '+'-\\'[i%n>n-2]+j(s[1:-1])+'-\\'[i%n>n-2]+len(f[0])/n*' 'for i,s in enumerate(zip(*f))]))

Experimente online!


5

Gelatina , 29 bytes

s”\⁹¦€Fð€0,1¦Zsð⁶ẋ;Ѐµ@"J;/z⁶

Os sinalizadores de entrada e saída são listas de linhas.
O comprimento da onda é 1 indexado.
Sempre produz uma linha de espaços.
(tudo isso acima é explicitamente permitido na pergunta postada)

Experimente online! (rodapé para deixar o IO bonito - pega e recebe sinalizadores como texto de várias linhas)

Quão?

Um método bastante semelhante à resposta 05ab1e da carusocomputing , que eu não consegui jogar mais.

s”\⁹¦€Fð€0,1¦Zsð⁶ẋ;Ѐµ@"J;/z⁶ - Main link: list of lists f, number p
            ¦                 - apply to indexes (of f)
         0,1                  - ... 0 paired with 1 (i.e. last & first -> bottom & top)
       ð€                     - the previous chain with p as right argument for €ach:
s                             -   split into chunks of length p
    ¦€                        -   apply to indexes for €ach
   ⁹                          -   ... link's right argument, p
 ”\                           -   the character '\' (a replacement - if the index is out of bounds this has no effect - although this might change in the future.)
             Z                - transpose the edited flag
              s               - split into chunks of length p
                        J     - range of length = [1,2,...,nChunks]
               ð     µ@"      - zip with reversed arguments (call those i):
                ⁶             -   literal space
                 ẋ            -    repeated i times
                  ;Ѐ         -    concatenate mapped across the chunks
                         ;/   - undo the split (reduce with concatenation)
                           z⁶ - transpose with a filler of space characters

Por que é sempre Jelly que faz isso?
Gryphon - Restabelece Monica

05AB1E venceu claramente esta rodada!
Jonathan Allan

OK, por que é sempre Jelly ou 05AB1E que faz isso? (Pergunta retórica, eu sei que é porque eles são línguas de golfe)
Gryphon - Reintegrar Monica


2

JavaScript (ES6), 175 bytes

f=(s,l,p=++l,t=s.replace(/^-*|-*$/g,s=>s.replace(/-/g,(c,i)=>++i%l?c:`\\`)))=>t.search`
`<p?t:(f(s,l,p+l,t)+`
`+` `.repeat(p)).replace(eval(`/(^|(.*)\\n)(.{${p}})/g`),`
$3$2`)
;
test=(s,l)=>document.write(`<pre>${s}
${l}${f(s,l)}</pre>`);
test(`---
abc
---`,2);
test(`-----
| + |
-----`,10);
test(`---------------------------------------
|&&&&&&                         &&&&&&|
|&&&&&&                         &&&&&&|
|&&&&&&                         &&&&&&|
|&&&&&&          .\\^/.          &&&&&&|
|&&&&&&        . |   | .        &&&&&&|
|&&&&&&        |\\|   |/|        &&&&&&|
|&&&&&&     .--'       '--.     &&&&&&|
|&&&&&&      \\           /      &&&&&&|
|&&&&&&       >         <       &&&&&&|
|&&&&&&      '~|/~~|~~\\|~'      &&&&&&|
|&&&&&&            |            &&&&&&|
|&&&&&&                         &&&&&&|
|&&&&&&                         &&&&&&|
---------------------------------------`,12);
test(`-----------------------
|-._\`-._ :| |: _.-'_.-|
|   \`-._\`:| |:\`_.-'   |
|-------\`-' '-'-------|
|------_.-. .-._------|
|  _.-'_.:| |:._\`-._  |
|-'_.-'  :| |:  \`-._\`-|
-----------------------`,4);
test(`---------------
---------------
---------------
---------------
---------------`,5);
test(`-------------------------------------------
|*  *  *  *  * |##########################|
| *  *  *  *  *|                          |
|*  *  *  *  * |##########################|
| *  *  *  *  *|                          |
|*  *  *  *  * |##########################|
| *  *  *  *  *|                          |
|*  *  *  *  * |##########################|
|---------------                          |
|#########################################|
|                                         |
|#########################################|
|                                         |
|#########################################|
-------------------------------------------`,0);

AE / S é como uma sequência delimitada por nova linha. A saída inclui uma nova linha líder; isso pode ser removido a um custo de 3 bytes. Eu tentei calcular a string de saída diretamente, mas isso me levou ... 176 bytes:

f=
(a,l,h=a.length)=>[...Array(h+(a[0].length-1)/++l|0)].map((_,i)=>a[0].replace(/./g,(k,j)=>((k=i-(j/l|0))&&h+~k)|-~j%l?(a[k]||'')[j]||' ':'\\'))
;
test=(s,l)=>document.write(`<pre>${s}
${l}
${f(s.split`
`,l).join`
`}</pre>`);
test(`---
abc
---`,2);
test(`-----
| + |
-----`,10);
test(`---------------------------------------
|&&&&&&                         &&&&&&|
|&&&&&&                         &&&&&&|
|&&&&&&                         &&&&&&|
|&&&&&&          .\\^/.          &&&&&&|
|&&&&&&        . |   | .        &&&&&&|
|&&&&&&        |\\|   |/|        &&&&&&|
|&&&&&&     .--'       '--.     &&&&&&|
|&&&&&&      \\           /      &&&&&&|
|&&&&&&       >         <       &&&&&&|
|&&&&&&      '~|/~~|~~\\|~'      &&&&&&|
|&&&&&&            |            &&&&&&|
|&&&&&&                         &&&&&&|
|&&&&&&                         &&&&&&|
---------------------------------------`,12);
test(`-----------------------
|-._\`-._ :| |: _.-'_.-|
|   \`-._\`:| |:\`_.-'   |
|-------\`-' '-'-------|
|------_.-. .-._------|
|  _.-'_.:| |:._\`-._  |
|-'_.-'  :| |:  \`-._\`-|
-----------------------`,4);
test(`---------------
---------------
---------------
---------------
---------------`,5);
test(`-------------------------------------------
|*  *  *  *  * |##########################|
| *  *  *  *  *|                          |
|*  *  *  *  * |##########################|
| *  *  *  *  *|                          |
|*  *  *  *  * |##########################|
| *  *  *  *  *|                          |
|*  *  *  *  * |##########################|
|---------------                          |
|#########################################|
|                                         |
|#########################################|
|                                         |
|#########################################|
-------------------------------------------`,0);

AE / S é como uma matriz de cadeias.


Parece que o único caso de teste que você passa é aquele que não muda.
317 Marie

Sim, isso não funciona corretamente para a maioria dos casos de teste. (O primeiro foi o que eu tentei)
Artyer

2
@ Artyer Desculpe, isso foi sutil; Não localizei o erro off-by-one.
Neil

2

PHP, 168 164 187 172 167 153 150 152 149 bytes

for($r=count($f=file(a));$y<$r+$e/$n=$argn;$y+=print"
")for($x=0;$x+1<$e=strlen($f[0])-1;)echo("\\".$f[$z=$y-($x/$n|0)][$x++]." ")[$z%($r-1)||$x%$n];

pega o sinalizador do arquivo estático ae o comprimento da onda (mínimo 1) de STDIN.
Execute como pipe php -nrou experimente online .

demolir

for($r=count($f=file(a));       # import file, count lines
    $y<$r+$e/$n=$argn;          # loop $y through lines
    $y+=print"\n")                      # 2. print newline
    for($x=0;$x+1<$e=strlen($f[0])-1;)  # 1. loop $x through columns
    echo("\\".$f[                           # 3. create string=backslash+character+space
            $z=$y-($x/$n|0)                 # 1. line no. = $y - wave offset
        ][$x++]." "                         # 2. pick character from line
        )
    [
        $z%($r-1)                           # if not first or last line
        ||$x%$n                             # or not last position of wave
    ]                                       # then index 1 (character or space), else "\\"
    ;

Não funciona para linhas no meio: sandbox.onlinephpfunctions.com/code/…
Artyer

Não deve transformar as linhas do meio em ``. Veja o caso de teste após o britânico
Artyer

Parece estar cortando alguns dos fundos de bandeiras que o aumento no tamanho muito: sandbox.onlinephpfunctions.com/code/...
Artyer

@ Artyer Deve ser isso.
Titus

1
$z&&$z!=$r-1deve ser equivalente a $z%($r-1)economizar 3 bytes.
Christoph
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.