Zrób falę flagi


26

Weź flagę, taką jak ta:

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

I wprowadzanie liczb: „długość fali”

Powiedzieć, że długość fali była 5. Następnie, co 5 znaków wzdłuż linii od początku, należy wymienić kolejną charakterem -z \i przesunąć wszystkie znaki po nim jeden wiersz w dół. Powtarzaj to do końca. Kończysz z:

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

Jeśli nie będziesz w stanie wykonać pełnej długości fali na końcu, flaga jest skończona. Pozostań płasko do końca.

Możesz założyć, że wszystkie wiersze mają tę samą długość oraz że górne i dolne wiersze składają się całkowicie z -(0x2D), a reszta znaków jest w !"#$%&\'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~, lub jest spacją ( ). (Więc jest to wartość ascii x, gdzie 31 < x < 127)
Flaga będzie miała co najmniej 3 wysokości i 3 szerokości.

Długość fali będzie nieujemną liczbą całkowitą (> = 0).

(Możesz także mieć długość fali 1 jako najmniejszą długość fali, więc powyższy przykład miałby długość fali 6. To jest OK.)

Twoje we / wy flagi mogą być jak tablice linii lub ciąg z wieloma liniami.

Flaga wyjściowa może mieć spacje końcowe, ale może mieć tylko spacje wiodące, o ile jest taka sama na każdej fladze. Końcowe spacje na fladze wejściowej mogą zostać usunięte.

Punktacja

To jest golf golfowy, więc wygrywa najkrótsze rozwiązanie w bajtach.

Przypadki testowe

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



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



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



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



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



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

4
Oczekiwanie, że @LuisMendo przyjedzie tutaj i zdmuchnie to w ciągu następnego dnia.
Magic Octopus Urn

Cholera ... Zapomniałem @ nie łączy tych, którzy nie odpowiedzieli ... Ktoś kopie mnie w tyłek za pomocą MATL, proszę, żebym mógł usunąć komentarze.
Magic Octopus Urn

2
Każdy ożywia to
Matthew Roh,

1
@SIGSEGV Gotowe , choć może nie to, co miałeś na myśli.
Brian McCutchon

1
@carusocomputing Czy ktoś do mnie zadzwonił? 31 bajtów
Luis Mendo,

Odpowiedzi:


11

05AB1E , 25 23 26 25 bajtów

-2 dzięki Adnan

-1 dzięki Emignie

+3 podziękowania dla Jonathana Allana (dzięki za poświęcenie czasu na złapanie tej nieważności!)

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

Wypróbuj online!

Jest to indeks 1 zamiast 0, +2 bajty, jeśli nie jest to w porządku.

ø                                    # 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 - musi istnieć lepsze rozwiązanie, aby zastąpić te skosy, ale jestem zakłopotany.


Indeksowanie 1 jest OK.
Artyer

1
újest taki sam jak ð×ì:)
Adnan

1
@Artyer wcale nie! +3 podziękowania dla niego za wskazanie, że moja odpowiedź jest nieprawidłowa, podoba mi się, gdy ludzie naprawdę dbają o to, aby przeczytać odpowiedź wystarczająco długo, aby zauważyć, że jest ona nieprawidłowa. Czy przeredagowałem to na tyle, żeby brzmiało mniej sarkastycznie: P?
Magic Octopus Urn

2
@Adnan ŻADNY CUD NIE MOGĘ NIGDY ODPOWIEDZIĆ NA NIEGO. Przepraszam, że zarżnąłem twoje imię Jonathan Allan .
Magic Octopus Urn

2
Naprawdę nie ma problemu :)
Jonathan Allan



5

Galaretka , 29 bajtów

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

Flagi wejściowe i wyjściowe są listami linii.
Długość fali jest indeksowana 1.
Zawsze tworzy jedną linię spacji.
(wszystkie powyższe są wyraźnie dozwolone w opublikowanym pytaniu)

Wypróbuj online! (stopka, aby wyglądać ładnie, we / wy - przyjmuje i odbiera flagi jako tekst wielowierszowy)

W jaki sposób?

Całkiem podobna metoda do odpowiedzi 05ab1e carusocomputing , której nie udało mi się jeszcze bardziej pograć w golfa.

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

Dlaczego to zawsze robi galaretka?
Gryphon - Przywróć Monikę

05AB1E wyraźnie wygrał tę rundę!
Jonathan Allan

OK, dlaczego to zawsze robi to Jelly lub 05AB1E? (Retoryczne pytanie, wiem, że to dlatego, że są golfistami)
Gryphon - Przywróć Monikę


2

JavaScript (ES6), 175 bajtów

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

I / O jest ciągiem rozdzielanym znakiem nowej linii. Dane wyjściowe obejmują wiodącą nową linię; można to usunąć kosztem 3 bajtów. Próbowałem bezpośrednio obliczyć ciąg wyjściowy, ale zajęło mi to ... 176 bajtów:

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

I / O ma postać tablicy łańcuchowej.


Wygląda na to, że jedynym przypadkiem testu, który zdasz, jest ten, który się nie zmienia.
Marie,

Tak, to nie działa poprawnie w większości przypadków testowych. (Pierwszy był tym, czego próbowałem)
Artyer

2
@Artyer Przepraszamy, to było subtelne; Nie zauważyłem błędu off-by-one.
Neil

2

PHP, 168 164 187 172 167 153 150 152 149 bajtów

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

pobiera flagę z pliku statycznego ai długość fali (minimum 1) ze STDIN.
Uruchom jako potok z php -nrlub spróbuj online .

awaria

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

Nie działa w przypadku linii na środku: sandbox.onlinephpfunctions.com/code/…
Artyer

Nie powinno zamieniać środkowych linii w ``. Zobacz przypadek testowy po brytyjskim
Artyer

Wygląda na to, że odcina
spodnią

@Artyer To powinno być to.
Tytus

1
$z&&$z!=$r-1powinno być równoważne $z%($r-1)zapisaniu 3 bajtów.
Christoph
Korzystając z naszej strony potwierdzasz, że przeczytałeś(-aś) i rozumiesz nasze zasady używania plików cookie i zasady ochrony prywatności.
Licensed under cc by-sa 3.0 with attribution required.