Wykonywanie oktogonalnych słów

14

W zeszły czwartek użytkownik @SpookyGengar zachwycił nas swoim pierwszym wyzwaniem dotyczącym tworzenia słów w kwadraty . Co jeśli podwoimy liczbę stron?

Wyzwanie

Weź ciąg jako dane wejściowe w dowolnym rozsądnym formacie, którego potrzebujesz ( string, chartablica ...) i wypisz ośmioboczną reprezentację danych wejściowych (także w dowolnym rozsądnym formacie: stringlista strings, charmacierz ...) jak w poniższych przykładach:

Input: golf
Output:

   golf
  o    l
 l      o
f        g
l        o
o        l
g        f
 o      l
  l    o
   flog


Input: HelloWorld
Output:

         HelloWorld
        e          l
       l            r
      l              o
     o                W
    W                  o
   o                    l
  r                      l
 l                        e
d                          H
l                          e
r                          l
o                          l
W                          o
o                          W
l                          o
l                          r
e                          l
H                          d
 e                        l
  l                      r
   l                    o
    o                  W
     W                o
      o              l
       r            l
        l          e
         dlroWolleH


Input: a
Output:

a


Input: ab
Output:

 ab
b  a
a  b
 ba


Input: code golf
Output:

        code golf
       o         l
      d           o
     e             g

   g                 e
  o                   d
 l                     o
f                       c
l                       o
o                       d
g                       e

e                       g
d                       o
o                       l
c                       f
 o                     l
  d                   o
   e                 g

     g             e
      o           d
       l         o
        flog edoc

Notatki

  • Dane wejściowe będą składały się wyłącznie z drukowalnych znaków ASCII.
  • Dozwolone i / lub końcowe białe spacje i znaki nowej linii są dozwolone, o ile zachowany jest kształt ośmiokątny.
  • To jest , więc niech wygra najmilszy program / funkcja dla każdego języka!
Charlie
źródło
5
„Co jeśli podwoimy liczbę stron?” <- wtedy węgiel nadal by wygrał
Leaky Nun
Sugerowany przypadek testowy:code golf
Leaky Nun
@LeakyNun jest <Space>uważany za drukowalny?
V. Courtois
2
@ V.Courtois yes
Leaky Nun
@LeakyNun dodał przypadek testowy.
Charlie,

Odpowiedzi:

10

Węgiel drzewny , 16 bajtów (10 bajtów niekonkurujących)

F⁸«✂θ⁰±¹↷¹A⮌θθ»θ

Wypróbuj online! Link jest do pełnej wersji kodu. Wyjaśnienie:

F⁸«                 Repeat for each side of the octagon
   ✂θ⁰±    ¹        Print the input except the last character
        ↷¹          Rotate 45° clockwise
          A⮌θθ      Reverse the input string
              »θ    Print the input again, to handle the length 1 case

Alternatywna długość 1 poprawka, również 16 bajtów: Wersja pełna.

PθF⁸«✂θ⁰±¹↷¹A⮌θθ

Poprawka błędu Charcoal oznacza, że ​​działa teraz następujący 10-bajtowy kod: Pełna wersja.

F⁴«θ←↘⮌θ↖⟲
Neil
źródło
wydaje się, że powinno to po prostu zrobić. Lol
Magic Octopus Urn
1
Umm, nie sądzę, że code golfdziała, prawda?
Erik the Outgolfer
Aha, i jest to w rzeczywistości 16 bajtów (wymienić θθθz θθ»θ).
Erik the Outgolfer
@EriktheOutgolfer Ups, przepraszam za to, nie pomyślałem o przetestowaniu mojej poprawki dla przypadku o długości 1 ... mój rekord testowy w pytaniu nie był zbyt dobry, prawda?
Neil
@Neil Ale co z problemem code golf? Myślę, że ma to związek ze sposobem, w jaki Charcoal bierze wkład, co niestety całkowicie go wyklucza z tego wyzwania, ponieważ nie można go obejść.
Erik the Outgolfer
5

JavaScript (ES6), 156 bajtów

f=
s=>[...Array((l=s.length-1)*3+1)].map((_,i,a)=>a.map((_,j)=>s[i+j-l?l*5-i-j?i+l*2-j?j+l*2-i?i%(l*3)?j%(l*3)?-1:j?i-l:l+l-i:i?l+l-j:j-l:j:l-i:l*3-i:i]||` `))
<input oninput=o.textContent=this.value?f(this.value).map(function(a){return(a.join``)}).join`\n`:``><pre id=o>

Zwraca tablicę znaków.

Neil
źródło
1
Wydaje się, że działa tylko z łańcuchami o długości 4.
Charlie,
1
@CllosAlejo Przepraszamy, nie sprawdziłem wystarczająco dokładnie. Dogodnie napraw zapisane 2 bajty!
Neil
Och, to dużo trójskładników ?:!
Erik the Outgolfer
@EriktheOutgolfer dobrze, że to nie jest python lub byłoby to naprawdę pełne: P
Stephen
3

Mathematica, 247 bajtów

(T=Table;k=Length[s=Characters@#];If[k==1,#,Column[Flatten@{#,T[""<>{s[[i]],T["  ",k/2-2+i],s[[-i]]},{i,2,k}],T[""<>{s[[-i]],T["  ",k+k/2-2],s[[i]]},{i,2,k}],T[""<>{s[[i]],T["  ",3k/2-1-i],s[[-i]]},{i,2,k-1}],StringReverse@#},Alignment->Center]])&
J42161217
źródło
Nie potrzebujesz Alignmenti oszczędzasz bajty, korzystając z opcji delayedset ( :=), aby zmniejszyć liczbę powtórzeń s[[i]]i s[[-i]], z tymi pomysłami spadasz do 224 bajtów: (T = Tabela; q: = s [[i]]; r: = s [[- i]]; k = Długość [s = Znaki @ #]; Jeśli [k == 1, #, Kolumna [Spłaszcz @ {#, T ["" <> {q, T ["", k / 2-2 + i], r}, {i, 2, k}], T ["" <> {r, T ["", k + k / 2-2], q}, {i, 2, k}], T ["" <> {q, T ["", 3k / 2-1-i], r}, {i, 2, k-1}], StringReverse @ #}, Center] ]) Oraz mam alternatywne rozwiązanie, które w momencie komentarza ma tylko 145 bajtów.
Mark S.
2

Pyth , 79 69 65 bajtów

j++K+]+*dJtlzzm+++*;-Jd@zd*;+ytdlz@z_hdSJjL*;t*3tlztC_B_zt__MC.tK

Zestaw testowy .

Leaky Nun
źródło
2

Japt , 84 79 bajtów

-5 bajtów dzięki @ETHproductions.


Ål
VoA{A?(UÅw +Uê)£Y¥V*2+AªY¥V-A?X:SÃ:Vç +U+Vç
Wf cU¬£V?(V*3 ç hUg~Y)+X:XÃcWz2

Wiodąca nowa linia jest częścią programu. Bierze ciąg jako dane wejściowe i zwraca tablicę ciągów.

Wypróbuj online! z -Rflagą, aby połączyć wynikową tablicę z nowymi liniami.

Nie moja największa praca, ale zmniejszyłem ją przynajmniej z ~ 100 bajtów. Moim pomysłem było stworzenie górnej i środkowej części, a następnie dołączenie górnej części, obróconej o 180 °.

Justin Mariner
źródło
Ładny. Nie widzę wiele ulepszeń od razu, ale może zmienić Ul Ésię UÅl, a przełącznik V i W, aby zaoszczędzić jeszcze 2 bajty: codepen.io/justinm53/full/...
ETHproductions
Również, AnV ?-> V-A?i Uq £->U¬£
ETHprodukcje
@ETHproductions Niesamowite, dzięki! Nie mogę uwierzyć, że zapomniałem ¬.
Justin Mariner,
1

Python 2 , 220 213 bajtów

  • Zaskakująco dłużej niż sobie wyobrażałem.
a=input()
l=len(a)
r=range(l)
print'\n'.join(p.center(l*3-2)for p in[a]+(l>1)*([a[i]+(2*i-2+l)*' '+a[~i]for i in r[1:-1]]+[a[~i]+(l*3-4)*' '+a[i]for i in r]+[a[i]+(3*l-2*i-4)*' '+a[~i]for i in r[1:-1]]+[a[::-1]]))

Wypróbuj online!

Officialaimm
źródło
1

PHP 7.1, 230 156 155 bajtów

for($x=$e=strlen($s=$argn)-1;$n<9;$r[$y][$x+=$n+1&3?$n&4?-1:1:0]=$s[$i],$i+=($n+=!$i||$i==$e)&1?:-1)$r[$y+=$n-1&3?$n<6?:-1:0]=$r[$y]?:"";echo join("
",$r);

Uruchom jako potok z -nRlub spróbuj online .

awaria

for($x=$e=strlen($s=$argn)-1;   # import to $s, set $e to length-1, init $x
    $n<9;                       # loop through 8 repetitions of string
    $r[$y][
        $x+=$n+1&3?$n&4?-1:1:0      # 3. increment/decrement $x depending on $n
    ]=$s[$i],                       # 4. copy character to current position
    $i+=(
        $n+=!$i||$i==$e             # 5. if first or last character of string, increment $n
    )&1?:-1                         # 6. if odd repetition next, else previous character
)
    $r[
        $y+=$n-1&3?$n<6?:-1:0       # 1. increment/decrement $y depending on $n
    ]=$r[$y]?:"";                   # 2. if empty, init row to string
echo join("\n",$r);             # output
Tytus
źródło
1

Mathematica, 168 166 147 127 bajtów

(n=Length@#;b=Array[" "&,3{n,n}-2];Do[l={{1,n+k-1},{k,n-k+1}};l=Join[l,Cross/@l];b=ReplacePart[b,Join[l,-l]->#[[k]]],{k,n}];b)&

Pobiera listę ciągów jednoznakowych i wyświetla macierz ciągów jednoznakowych.

Uratowałem 18 bajtów przez wykorzystanie symetrii w użyciu -li Cross/@lktóry bierze coś w przekroju produktu z każdej z dwóch pojedynczych wektorów 2D do podjęcia {x,y}się {-y,x}. Zasadniczo dwa początkowe kierunki to wschód (górna krawędź) i południowy zachód (górna prawa krawędź). Następnie dodajemy ich obrót o 90 stopni w kierunku przeciwnym do ruchu wskazówek zegara z Cross: Północ dla lewej krawędzi i południowy wschód dla lewej dolnej krawędzi. Następnie dodajemy pozostałe cztery elementy za pomocą-l do odwrócenia czterech, które omówiliśmy.

Możesz to przetestować na piaskownicy za pomocą czegoś takiego:

(n=Length@#;b=Array[" "&,3{n,n}-2];Do[l={{1,n+k-1},{k,n-k+1}};l=Join[l,Cross/@l];b=ReplacePart[b,Join[l,-l]->#[[k]]],{k,n}];b)&[{"H","e","l","l","o"," ","G","o","l","f"}]//MatrixForm
Znaki.
źródło