Rendere valido un programma di triangolarità


19

Triangularity è un nuovo esolang sviluppato da Mr. Xcoder in cui la struttura del codice deve seguire uno schema molto specifico:

  • Per la nriga di codice, devono esserci esattamente i 2n-1caratteri del programma su di esso. Ciò provoca una forma triangolare / piramidale, con la prima riga che ha un solo carattere e il resto che aumenta di incrementi di 2.
  • Ogni riga deve essere riempita con .s a sinistra e a destra, in modo tale che i caratteri siano centrati sulle loro linee e tutte le linee siano riempite alla stessa lunghezza. Se lè definito come il numero di righe nel programma, ogni riga nel programma deve avere una lunghezza di2 * l - 1

Ad esempio, il programma a sinistra è valido, ma il programma a destra non è:

 Valid    |  Invalid  
          |
...A...   |  ABCDE
..BCD..   |  FGH
.EFGHI.   |  IJKLMN
JKLMNOP   |  OPQRS

Se disposto nella struttura valida, il nome diventa evidente.

Compito

Il tuo compito è quello di prendere una stringa a riga singola come input, che rappresenta il codice di triangolarità, e di convertirla in un codice valido come descritto sopra.

Specifiche per I / O:

  • L'input conterrà solo caratteri nell'intervallo 0x20 - 0x7e
  • La lunghezza dell'input sarà sempre un numero quadrato e quindi facilmente riempibile.
  • È necessario utilizzare i punti per il riempimento dell'output, non qualcos'altro.

È possibile immettere e produrre qualsiasi metodo accettabile . Questo è un quindi vince il codice più corto in byte !

Casi test

input
----
output

g
----
g

PcSa
----
.P.
cSa

DfJ0vCq7G
----
..D..
.fJ0.
vCq7G

7xsB8a1Oqw5fhHX0
----
...7...
..xsB..
.8a1Oq.
w5fhHX0

QNYATbkX2sKZ6IuOmofwhgaef
----
....Q....
...NYA...
..TbkX2..
.sKZ6IuO.
mofwhgaef

ABCDEF"$%& G8"F@
----
...A...
..BCD..
.EF"$%.
& G8"F@

ab.c
----
.a.
b.c

Per coloro che conoscono la triangolarità, dall'ultimo caso di test noterete che le stringhe non devono essere gestite



13
Mi rendo conto che questo è probabilmente inutile, ma al downvoter interessa spiegare il proprio voto? Mi piacerebbe migliorare la sfida in ogni modo possibile.
caird coinheringaahing il

Sono accettabili le linee guida iniziali o finali?
Arnauld

@Arnauld Sì, lo spazio bianco iniziale e finale va perfettamente bene.
caird coinheringaahing il

Un elenco di righe va bene?
Mr. Xcoder,

Risposte:


19

Triangolarità , 127 byte

.......).......
......2)1......
...../)IL^.....
....f)rMD@_....
...)2)1/)IL^...
..f+`"'.'*"+E..
.DWReD)2s^)Its.
D+@sh+s+})10cJ.

Provalo online!

Spiegazione

Rimuovendo i caratteri che compongono il riempimento, otteniamo il seguente programma:

)2)1/)IL^f)rMD@_)2)1/)IL^f+`"'.'*"+EDWReD)2s^)ItsD+@sh+s+})10cJ

... Qual è abbastanza lungo, giusto? Dividiamolo in pezzi.

Generazione di numeri interi [0… √len (input))

)2)1/)IL^f)r – Subprogram #1.
)            – Creates a new stack entry, equal to 0. This must precede any integer
               literal, because each character in '0123456789' isn't parsed on its
               own as a literal, but rather they are commands which multiply the ToS
               by 10 and add the value of their digit equivalent. 
 2           – ToS * 10 + 2 = 2.           || STACK: [2]
  )1         – The literal 1.              || STACK: [2, 1]
    /        – Division.                   || STACK: [1 / 2] = [0.5]
     )I      – Get the input at index 0.   || STACK: [0.5, input]
       L     – Length.                     || STACK: [0.5, len(input)]
        ^    – Exponentiation.             || STACK: [len(input) ** 0.5]
         f   – Trim decimals.              || STACK: [int(len(input) ** 0.5)] 
          )r – Create the list [0 .. ToS). || STACK: [[0 ... int(len(input) ** 0.5))]

Generare i punti

MD@_)2)1/)IL^f+`"'.'*"+E – Subprogram #2.
MD                       – For each integer in the range, run some code on a separate
                           stack, preinitialised to two copies of the argument.
  @_                     – Increment and negate the ToS.
    )2)1/)IL^f           – The square root of the length of the input, again.
              +          – Add the two.
               `         – And cast the integer given to a string.
                "'.'*"+  – Prepends the literal "'.'*" to the string representation.
                       E – Evaluate as a Python expression (basically string repetition).

Ritagliare i personaggi nella parte anteriore

DWReD)2s^)It – Subprogram #3.
D            – Duplicate the result of the expression above.
 W           – Wrap the whole intermediate stack to an array.
  Re         – Reverse the stack and dump the contents separately onto the stack.
    D        – Duplicate the result.
     )2      – Push the literal 2.
       s^    – Swap and perform exponentiation.
         )It – Push the input and trim the characters before that index.

Ritagliare i personaggi alla fine

sD+@sh+s+ – Subprogram #4.
s         – Swap the top two elements on the stack.
 D+       – Double. Push twice and add.
   @      – Increment.
    sh    – Swap the top two elements and trim the characters after that index.
      +   – Append the first set of dots.
       s+ – And prepend the second set of dots.

Fine del ciclo e bella stampa

})10cJ – Subprogram #5.
}      – End the loop.
 )10   – Push the literal 10.
    c  – Convert from code-point to character (yields '\n').
     J – And join the result by newlines.

devi segnare byte per il "." personaggi se sono obbligati dagli intrinseci della lingua?
JDL,

@JDL Sì, il programma non può funzionare correttamente senza di essi, quindi devo includerli nel conteggio dei byte :-)
Mr. Xcoder,

Devi "tagliare i decimali", visto che la lunghezza dell'input è garantita quadrata? Dovresti anche essere in grado di ottenere l'asta Jalla fine e produrre una serie di linee. Non so se questo ti salverà qualcosa, tuttavia, se è necessario .riempire la fine dell'ultima riga per riempire lo spazio rimanente.
Shaggy,

1
@Shaggy 1) Sì, fè necessario perché range non può accettare argomenti float (anche con .0) 2) Sbarazzarsi di Jnon salvare alcun byte a causa del riempimento, quindi ho scelto il formato di output più carino.
Mr. Xcoder,

8

Japt , 15 14 10 byte

Emette un array di linee.

ò@°T¬v1Ãû.

Provalo | Controlla tutti i casi di test


explantion

ò@     Ã       :Partition at characters where the following function returns true
  °T           :  Increment T (initially 0)
    ¬          :  Square root
     v1        :  Divisible by 1?
               :(Or, in other words, split after every character with a 1-based index that's a perfect square)
        û.     :Centre pad each element with .s to the length of the longest element

Soluzione originale

ʬÆsTT±X+°XÃû.

Provalo

Ê                  :Length of input
 ¬                 :Square root
  Æ        à       :Range [0,ʬ) and pass each X through a function
   s               :  Slice input
    T              :    from index T, initially 0
     T±X+°X        :    to index T incremented by X plus X incremented
            û.     :Centre pad each element with .s to the length of the longest element

7

Buccia , 15 byte

Ṡzö`JR2tR'.ṡCİ1

Provalo online!

Spiegazione

Ṡzö`JR2tR'.ṡCİ1  Implicit input, say s = "DfJ0vCq7G".
             İ1  List of odd positive integers: [1,3,5,7,..
            C    Cut s to those lengths: x = ["D","fJ0","vCq7G"]
           ṡ     Reversed indices of x: y = [3,2,1]
Ṡz               Zip x and y using this function:
                  Arguments are a string and a number, e.g. r = "fJ0" and n = 2.
        R'.       n copies of '.': ".."
       t          Drop first element: "."
     R2           Two copies of this: [".","."]
  ö`J             Join by r: ".fJ0."
                 Result is ["..D..",".fJ0.","vCq7G"]; implicitly print on separate lines.

7

05AB1E , 20 19 18 byte

Salvataggio di un byte grazie a Magic Octopus Urn

ā·<£õKRvy'.N×.ø}r»

Provalo online!

Spiegazione

ā                    # push the list [1 ... len(input)]
 ·<                  # multiply each by 2 and decrement each, making a list of odd numbers
   £                 # split the input into chunks of these sizes
    õK               # remove empty strings
      R              # reverse list
       vy      }     # for each y in the list
             .ø      # surround it with
         '.N×        # "." (dot) repeated N times, where N is the current iteration index
                r    # reverse the stack
                 »   # join stack by newlines

ÅÉper probabilità può aiutare?
Magic Octopus Urn,

Qualcosa del tipo g;ÅÉ£Rvy'.N×.ø}r»,? Ma non perché non è giusto lol.
Magic Octopus Urn

@MagicOctopusUrn: ÅÉsarebbe sicuramente di aiuto se potessimo scoprire la lunghezza della riga inferiore in 2 byte. Non so se possiamo però. Potrebbe essere un altro modo per incorporarlo.
Emigna,

@MagicOctopusUrn: ho avuto questa stessa soluzione in precedenza, tranne che ho usato al )Rposto del rquale non ho salvato alcun byte: /
Emigna

Stavo cercando di trovare un modo per "invertire il ciclo" per stampare solo quando si presenta, nessuna idea su questo però.
Magic Octopus Urn,


5

Gelatina ,  22 anni  19 byte

J²‘Ṭœṗ⁸Ṛz”.Zµṙ"JC$Ṛ

Un collegamento monadico che restituisce un elenco di elenchi di caratteri (le righe)

Provalo online!

Come?

J²‘Ṭœṗ⁸Ṛz”.Zµṙ"JC$Ṛ - Link: list of characters e.g. "DfJ0vCq7G"
J                   - range of length               [1,2,3,4,5,6,7,8,9]
 ²                  - square (vectorises)           [1,4,9,16,25,36,49,64,81]
  ‘                 - increment                     [2,5,10,17,26,37,50,65,82]
   Ṭ                - untruth (1s at those indices) [0,1,0,0,1,0,0,0,0,1,0,0,0,0,0,0,1,...]
      ⁸             - chain's left argument         "DfJ0vCq7G"
    œṗ              - partition at indexes          ["D","fJ0","vCq7G"]
       Ṛ            - reverse                       ["vCq7G","fJ0","D"]
         ”.         - literal '.'                   '.'
        z           - transpose with filler         ["vfD","CJ.","q0.","7..","G.."]
           Z        - transpose                     ["vCq7G","fJ0..","D...."]
            µ       - start a new monadic chain
                 $  - last two links as a monad:
               J    -   range of length             [1,2,3]
                C   -   complement (vectorises)     [0,-1,-2]
              "     - zip with:
             ṙ      -   rotate left by              ["vCq7G",".fJ0.","..D.."]
                  Ṛ - reverse                       ["..D..",".fJ0.","vCq7G"]

5

JavaScript (ES7), 82 78 byte

f=(s,k=1-s.length**.5*2,p='')=>s&&f(s.slice(0,k),k+2,p+'.')+`
`+p+s.slice(k)+p

Casi test

Commentate

f = (                       // f = recursive function taking:
  s,                        //   s = input string
  k = 1 - s.length**.5 * 2, //   k = additive inverse of the length of the base
  p = ''                    //   p = padding string
) =>                        //
  s &&                      // if s is not empty:
    f(                      //   do a recursive call with:
      s.slice(0, k),        //     s without the last -k characters
      k + 2,                //     the updated base length (2 less characters)
      p + '.'               //     the updated padding string
    ) +                     //   end of recursive call()
    `\n` +                  //   append a line feed
    p +                     //   append the left padding string
    s.slice(k) +            //   append the last -k characters of s
    p                       //   append the right padding string

[minore] il simbolo '/ n' è diventato una vera interruzione di riga nel blocco di codice in alto - considera la possibilità di scappare per chiarezza :)
G0BLiN,

@ G0BLiN Questo è il contrario: si tratta in effetti di un'interruzione letterale del codice del golf, che è stata sostituita con un'interruzione di linea in escape nella versione non golfata per maggiore chiarezza. :)
Arnauld,

Ah, scherzo, allora ... :-)
G0BLiN,


2

MATL , 21 byte

tnX^eRP&1ZvGyg(46y~(!

Provalo online!

Spiegazione

Considera l'input 'DfJ0vCq7G'come esempio. I contenuti dello stack vengono visualizzati separati da virgole, con l'ultimo elemento ultimo. Le righe in un array 2D usano il punto e virgola come separatore.

t      % Implicit input: string. Duplicate
       % STACK: 'DfJ0vCq7G',
                'DfJ0vCq7G'
nX^    % Number of elements. Square root
       % STACK: 'DfJ0vCq7G',
                3
e      % Reshape with that many rows (in column major order)
       % STACK: ['D0q';
                 'fv7';
                 'JCG']
R      % Upper triangular part: set elements below diagonal to char(0)
       % (displayed as space)
       % STACK: ['D0q';
                 ' v7';
                 '  G']
P      % Flip vertically
       % STACK: ['  G';
                 ' v7';
                 'D0q']
&1Zv   % Reflect vertically
       % STACK: ['  G';
                 ' v7';
                 'D0q';
                 ' v7';
                 '  G']
G      % Push input again
       % STACK: ['  G';
                 ' v7';
                 'D0q';
                 ' v7';
                 '  G'],
                'DfJ0vCq7G'
yg     % Duplicate from below and convert to logical. This gives true for
       % for nonzero chars (the entries where input chars will be written)
       % STACK: ['  G';
                 ' v7';
                 'D0q';
                 ' v7';
                 '  G'],
                'DfJ0vCq7G',
                [0 0 1;
                 0 1 1;
                 1 1 1;
                 0 1 1;
                 0 0 1]
(      % Assignment indexing: write values at those positions
       % STACK: ['  v';
                 ' fC';
                 'DJq';
                 ' 07';
                 '  G']
46     % Push 46, which is ASCII for '.'
       % STACK: ['  v';
                 ' fC';
                 'DJq';
                 ' 07';
                 '  G'],
                 46
y~     % Duplicate from below and apply logical negate. This gives true
       % for char(0) (the entries where '.' will be written)
       % STACK: ['  G';
                 ' v7';
                 'D0q';
                 ' v7';
                 '  G'],
                46
                [1 1 0;
                 1 0 0;
                 0 0 0;
                 1 0 0;
                 1 1 0]
(      % Assignment indexing: write value at those positions
       % STACK: ['..G';
                 '.v7';
                 'D0q';
                 '.v7';
                 '..G'],
!      % Transpose. Implicit display
       % STACK: ['..D..';
                 '.fJ0.';
                 'vCq7G']

2

Pulito , 107 94 89 88 byte

import StdEnv
@s _[]=s
@s n r= @([['.':l]++['.']\\l<-s]++[take n r])(n+2)(drop n r)

@[]1

Provalo online! Esempio di utilizzo: @[]1 ['ABCDEF"$%& G8"F@'].


1

Haskell , 84 68 byte

[]%1
(s%n)[]=s
(s%n)r=(['.':l++"."|l<-s]++[take n r])%(n+2)$drop n r

Provalo online!

Esempio di utilizzo: []%1 $ "abcd"restituisce l'elenco di righe [".a.","bcd"].


1

Perl, 56 52 byte

Include +3per-p

#!/usr/bin/perl -p
$_=("."x y///c**.5)=~s%.%$'@{[$&x/$`$`./g]}$'
%rg

Fornisci input su STDIN (in linea di principio senza newline finale, ma questo è importante solo per l'input vuoto)


1
secondo le regole PCG -pcosta solo 1 byte
mik

@mik Solo se il codice non contiene '. Ma questo codice lo fa, quindi deve essere inserito in un file (o in escape sulla riga di comando) che richiede 3 caratteri extra rispetto alla #!linea normale . Quindi in questo caso lo è +3(per il codice normale vedrai che in effetti conto solo +per p)
Ton Hospel,

1

Rosso , 227 203 byte

f: func[s][l: to-integer(length? s)** 0.5
n: 0 foreach m parse s[collect[(r: []repeat i l[append r reduce['keep i * 2 - 1
charset[not{Я}]]])r]][v: copy""insert/dup v"."l - n: n + 1 print rejoin[v m v]]]

Provalo online!

Ungolfed:

f: func[s][
l: to-integer (length? s) ** 0.5
n: 0
foreach m parse s [ 
    collect [
        (r: []
        repeat i l [ append r reduce [
            'keep i * 2 - 1 charset [ not{Я} ]]])
    r ]] 
    [v: copy ""
    insert/dup v "." l - n: n + 1
    print rejoin [v m v]]
]

1

Retina , 88 72 71 byte

S1`
+m`^(.)+¶(?>(?<-1>.)+)..(?!¶)
$&¶
P^'.m`^.(?=(..)*)(?<-1>.)*
P'.`.+

Provalo online! Modifica: salvato 12 13 byte grazie a @MartinEnder. Spiegazione:

S1`

Dividi il primo personaggio nella sua stessa linea per far rotolare la palla.

+m`^(.)+¶(?>(?<-1>.)+)..(?!¶)
$&¶

Taglia ogni riga di due caratteri più lunghi di quello precedente.

P^'.m`^.(?=(..)*)(?<-1>.)*

Pad sinistro della prima metà di ogni riga, centrandoli efficacemente.

P'.`.+

Pad destro di tutte le linee.


1

Carbone di legna , 21 19 byte

UB.F₂Lθ«P✂θXι²X⊕ι²↙

Provalo online! Il collegamento è alla versione dettagliata del codice. Modifica: salvato 2 byte scoprendo SquareRoot. Spiegazione:

UB.                 Set the background fill to `.`
      θ             (First) input
     L              Length
    ₂               Square root
   F   «            Loop over implicit range
            ι   ι   Current value
               ⊕    Incremented
             ²   ²  Literal 2
           X  X     Power
         ✂θ         Slice the (first) input string
        P           Print without moving the cursor
                  ↙ Move down left

: / Questo funziona quasi, ma sembra che il carbone sia un po 'difettoso. Questo funziona però, credo?
ASCII,

@ Solo ASCII ... che magia nera è questa?
Neil,

Fill controlla sostanzialmente i byte null (ovvero il carattere utilizzato per lo spazio in cui non viene disegnato nulla), quindi puoi semplicemente disegnare un poligono con byte null (beh, se funziona anche correttamente> _>) e riempirlo. Ovviamente questo non è esattamente inteso poiché puoi effettivamente vedere i byte null anche prima del riempimento per qualche motivo> _>
ASCII-only

questo dovrebbe funzionare correttamente al prossimo pull
solo ASCII il



0

rubino , 73 66 byte

->s{(1..z=s.size**0.5).map{|q|s[q*q-2*q+1...q*q].center 2*z-1,?.}}

Provalo online!

-5 byte: restituisce un array di stringhe invece di stamparle

-2 byte: dichiarare zin posizione anziché in anticipo

Ungolfed:

->s{
  (1..z=s.size**0.5).map{|q|   # Map the range [1,sqrt(s.size)]
    s[q*q-2*q+1...q*q]         # To the relevant portion of s,
      .center 2*z-1, ?.        #   padded left and right with . characters
  }
}

Dichiarare una variabile r=q-1 modo che io possa prendere s[r*r...q*q]salva esattamente zero byte.

L'utilizzo .centerinvece del riempimento manuale consente di risparmiare zero byte, ma mi piace di più.


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.