三角法プログラムを有効にする


19

Triangularityは、Xcoder氏によって開発された新しいエソランであり、コード構造は非常に具体的なパターンに従う必要があります。

  • nコードのth行について2n-1は、プログラムの正確な文字がその上になければなりません。これにより、最初の行は1文字のみで、残りは2ずつ増加する三角形/ピラミッドの形状になります。
  • 各行の.左右にsを埋め込み、文字が行の中央に配置され、すべての行が同じ長さで埋め込まれるようにする必要があります。lがプログラムの行数として定義されている場合、プログラムの各行の長さは2 * l - 1

たとえば、左側のプログラムは有効ですが、右側のプログラムは無効です。

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

有効な構造にレイアウトすると、名前が明らかになります。

仕事

あなたの仕事は、三角コードを表す単一行の文字列を入力として受け取り、それを上記のように有効なコードに変換して出力することです。

I / Oの仕様:

  • 入力には、範囲内の文字のみが含まれます 0x20 - 0x7e
  • 入力の長さは常に二乗数であるため、うまくパディング可能です。
  • 出力パディングには、他のものではなくドットを使用する必要があります。

受け入れ可能な任意の方法で入力および出力できます。これはので、バイト単位の最短コードが勝ちです!

テストケース

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

三角性を知っている人にとっては、最後のテストケースから文字列を処理する必要がないことに気付くでしょう。



13
これはおそらく無駄なことだと思いますが、投票者は投票を説明するのを気にかけますか?とにかくできる限りチャレンジを改善したいと思います。
コメアリンガーアーイング

先頭または末尾の改行は受け入れられますか?
アーナウルド

@Arnauldはい、先頭と末尾の空白はまったく問題ありません。
コイアリンガーアーイング

行のリストに問題はありませんか?
ミスターXcoder

回答:


19

三角度、127バイト

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

オンラインでお試しください!

説明

パディングを構成する文字を削除すると、次のプログラムが取得されます。

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

...どちらがかなり長めですよね?それを断片に分けましょう。

整数の生成[0…√len(入力))

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

ドットを生成する

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

前面のキャラクターをトリミングする

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.

最後の文字のトリミング

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.

ループの終了ときれいな印刷

})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.

「。」のバイト数を記録する必要がありますか 文字が言語の組み込み関数によって強制されている場合
JDL

@JDLはい、プログラムはそれらなしでは正しく実行できないため、バイトカウントに含める必要があります:
Xcoder氏18

入力の長さが正方形であることが保証されているため、「小数を切り捨てる」必要がありますか?またJ、最後にロッドを取得し、行の配列を出力できる必要があります。ただし、最後の行の終わりに.残りのスペースを埋めるためにパディングする必要がある場合、それがあなたを救うかどうかはわかりません。
シャギー

1
@Shaggy 1)はい、f範囲は浮動小数点引数を受け入れることができないため(であっても.0)2)が必要Jです。
Mr Xcoder

8

Japt15 14 10バイト

行の配列を出力します。

ò@°T¬v1Ãû.

それを試してください | すべてのテストケースを確認する


外植

ò@     Ã       :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

オリジナルソリューション

ʬÆsTT±X+°XÃû.

それを試してみてください

Ê                  :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

、15バイト

Ṡzö`JR2tR'.ṡCİ1

オンラインでお試しください!

説明

Ṡ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

05AB1E20 19 18バイト

Magic Octopus Urnのおかげで1バイト節約

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

オンラインでお試しください!

説明

ā                    # 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

ÅÉオッズが役立つかもしれませんか?
魔法のタコ

なんかg;ÅÉ£Rvy'.N×.ø}r»?しかし、そうではありません。
魔法のタコ

@MagicOctopusUrn:ÅÉ最下行の長さを2バイトで調べることができれば間違いなく役立ちます。できるかどうかはわかりません。同様に組み込む別の方法かもしれません。
エミグナ

@MagicOctopusUrn:バイトを保存しない)R代わりに使用したことを除いて、以前と同じソリューションを使用しましたr:/
Emigna

私は「ループを逆にする」方法を見つけようとしていました。
魔法のタコ


5

ゼリー 22  19 バイト

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

文字のリスト(行)のリストを返すモナドリンク

オンラインでお試しください!

どうやって?

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バイト

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

テストケース

コメント済み

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

[マイナー] '/ n'記号は、上部のコードブロックで実際の改行になりました-明確にするためにエスケープすることを検討してください:)
G0BLiN

@ G0BLiNこれは別の方法です。これ実際、ゴルフコードのリテラル改行であり、わかりやすくするために、非ゴルフバージョンではエスケープされた改行に置き換えられています。:)
アーナウルド

ハ、冗談は私に、それから... :-)
G0BLiN


2

MATL、21バイト

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

オンラインでお試しください!

説明

'DfJ0vCq7G'例として入力を検討してください。スタックの内容はコンマで区切られて表示され、一番上の要素が最後になります。2D配列の行では、セミコロンが区切り記号として使用されます。

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



1

Perl、56 52バイト

含み+3のために-p

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

STDINに入力します(原則として最終改行はありませんが、それは空の入力にのみ関係します)


1
PCGルールに従って-pコストのみ1バイト
MIK

@mikコードにが含まれていない場合のみ'。しかし、このコードはそうなので、通常の#!行と比較して3つの余分な文字を必要とするファイル(またはコマンドラインでエスケープ)に配置する必要があります。したがって、この場合はそうです+3(通常のコードの場合、実際にカウントさ+れるのはp)だけです
トンホスペル

1

227203バイト

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

オンラインでお試しください!

ゴルフをしていない:

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

網膜88 72 71バイト

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

オンラインでお試しください!編集:@MartinEnderのおかげで12 13バイトを保存しました。説明:

S1`

最初のキャラクターを独自の行に分割して、ボールを転がします。

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

各行を前の行よりも2文字長く切り取ります。

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

各行の前半分を左詰めし、効果的に中央揃えにします。

P'.`.+

すべての行を右詰めします。


1

21 19バイト

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

オンラインでお試しください!リンクは、コードの詳細バージョンです。編集:を発見して2バイトを保存しましたSquareRoot。説明:

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

:/ これはほとんど機能しますが、チャコールは少しバグが多いようです。これは動作しますが、私は思う?
ASCIIのみ

@ASCIIのみ...これはどんな黒魔術ですか?
ニール

塗りつぶしは基本的にnullバイト(つまり、何も描画されないスペースに使用される文字)をチェックするので、nullバイトのポリゴンを描画するだけで(正しく動作する場合は> _>)、塗りつぶすことができます。明らかに、何らかの理由でフィルの前でもヌルバイトを見ることができるため、これは厳密には意図されていません> _>
ASCIIのみ

この正しく、次のプル動作するはずです
ASCIIのみ



0

ルビー73 66バイト

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

オンラインでお試しください!

-5バイト:文字列を出力する代わりに返します

-2バイト:宣言 z事前にではなく所定の場所で

ゴルフをしていない:

->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
  }
}

r=q-1私が取ることができるように変数を宣言するs[r*r...q*q]正確にゼロバイト節約されます。

.center手動でパディングする代わりに使用すると、ゼロバイトが節約されますが、私はそれが好きです。


弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.