Fare parole ottagonali


14

Giovedì scorso l'utente @SpookyGengar ci ha deliziato con la sua prima sfida su Making Squared Words . E se raddoppiassimo il numero di lati?

La sfida

Prendi una stringa come input in qualsiasi formato ragionevole di cui hai bisogno ( string, chararray ...) e genera una rappresentazione ottagonale dell'input (anche in qualsiasi formato ragionevole:, stringelenco di strings, charmatrice ...) come nei prossimi esempi:

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

Appunti

  • L'input consisterà solo di caratteri ASCII stampabili.
  • Spazi bianchi e newline iniziali e / o finali consentiti purché venga mantenuta la forma ottagonale.
  • Questo è , quindi può vincere il programma / la funzione più ordinato per ogni lingua!

5
"E se raddoppiassimo il numero di lati?" <- allora il carbone vincerebbe ancora
Leaky Nun

Testcase suggerito:code golf
Leaky Nun,

@LeakyNun è <Space>considerato stampabile?
V. Courtois,

2
@ V.Courtois
Leaky Nun

@LeakyNun aggiunto test case.
Charlie,

Risposte:


10

Carbone , 16 byte (10 byte non competitivi)

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

Provalo online! Il collegamento è alla versione dettagliata del codice. Spiegazione:

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

Correzione alternativa di lunghezza 1, anche 16 byte: versione dettagliata.

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

Un bugfix per Charcoal significa che ora funziona il seguente codice a 10 byte: Versione dettagliata.

F⁴«θ←↘⮌θ↖⟲

sembra che dovrebbe farlo. Lol
Magic Octopus Urn

1
Umm, non penso code golfche funzioni?
Erik the Outgolfer,

Oh, e questo è in realtà 16 byte (sostituisci θθθcon θθ»θ).
Erik the Outgolfer,

@EriktheOutgolfer Oops, mi dispiace, non ho pensato di testare la mia correzione per il caso di lunghezza 1 ... il mio record di test sulla domanda non è stato molto buono, vero?
Neil,

@Neil Ma per quanto riguarda il problema code golf? Penso che abbia a che fare con il modo in cui il carbone prende input, il che, sfortunatamente, lo squalifica completamente da questa sfida in quanto non può essere eluso.
Erik the Outgolfer,

5

JavaScript (ES6), 156 byte

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>

Restituisce una matrice di caratteri.


1
Sembra funzionare solo con stringhe di lunghezza 4.
Charlie

1
@CarlosAlejo Siamo spiacenti, non ho controllato abbastanza attentamente. Convenientemente, correggi 2 byte salvati!
Neil,

Oh mio che è un sacco di ternary ?:!
Erik the Outgolfer,

@EriktheOutgolfer buona cosa non è pitone o sarebbe davvero prolisso: P
Stephen

3

Mathematica, 247 byte

(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]])&

Non hai bisogno Alignmente risparmierai byte usando delayedset ( :=) per ridurre la ripetizione di s[[i]]e s[[-i]], scendi a 224 byte con queste idee: (T = Tabella; q: = s [[i]]; r: = s [[- i]]; k = Lunghezza [s = Caratteri @ #]; Se [k == 1, #, Colonna [Appiattisci @ {#, 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] ]) Inoltre, al momento di questo commento ho una soluzione alternativa di soli 145 byte.
Mark S.


2

Japt , 84 79 byte

-5 byte grazie a @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

Newline leader fa parte del programma. Accetta una stringa come input e restituisce una matrice di stringhe.

Provalo online! con il-R flag per unire l'array risultante con le nuove righe.

Non è il mio lavoro più orgoglioso, ma ho ottenuto almeno ~ 100 byte. La mia idea qui era quella di creare le parti superiore e centrale, quindi aggiungere la parte superiore, ruotata di 180 °.


Bello. Non vedo subito molti miglioramenti, ma potresti cambiare Ul Éin UÅl, e cambiare V e W per salvare altri 2 byte: codepen.io/justinm53/full/…
ETHproductions

Inoltre, AnV ?-> V-A?, e Uq £->U¬£
ETHproductions

@ETHproductions Fantastico, grazie! Non riesco a credere di essermi dimenticato ¬.
Justin Mariner,

1

Python 2 , 220 213 byte

  • Sorprendentemente più a lungo di quanto avessi immaginato.
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]]))

Provalo online!


1

PHP 7.1, 230 156 155 byte

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

Esegui come pipe -nRo provalo online .

abbattersi

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

1

Mathematica, 168 166 147 127 byte

(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)&

Questo prende un elenco di stringhe di un carattere e genera una matrice di stringhe di un carattere.

Ho salvato 18 byte sfruttando la simmetria utilizzare -le Cross/@lche prende qualcosa come un prodotto incrociato di ciascuno dei due singoli vettori 2D a prendere {x,y}a {-y,x}. Fondamentalmente, le due direzioni iniziali sono Est (bordo superiore) e Sud-ovest (bordo superiore destro). Quindi aggiungiamo rotazioni in senso antiorario di 90 gradi conCross : Nord per il bordo sinistro e Sud-est per il bordo inferiore sinistro. Quindi aggiungiamo gli altri quattro pezzi usando-l per capovolgere i quattro che abbiamo coperto.

Puoi provarlo sulla sandbox con qualcosa del tipo:

(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
Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.