ASCII Pylonsを構築する必要があります!


24

私のアナゴルフ投稿からクロス投稿(注:ネタバレが含まれている場合があります、死後)。

次のテキストを正確に出力します。

  • 各行に後続の空白があり、後続の改行もあります。
  • バイト単位の最短コードが優先されます。
                                                
                                              !"!
                                             "#$#"
                                            #$%&%$#
                                           $%&'('&%$
                                          %&'()*)('&%
                                         &'()*+,+*)('&
                                        '()*+,-.-,+*)('
                                       ()*+,-./0/.-,+*)(
                                      )*+,-./01210/.-,+*)
                                     *+,-./012343210/.-,+*
                                    +,-./0123456543210/.-,+
                                   ,-./01234567876543210/.-,
                                  -./0123456789:9876543210/.-
                                 ./0123456789:;<;:9876543210/.
                                /0123456789:;<=>=<;:9876543210/
                               0123456789:;<=>?@?>=<;:9876543210
                              123456789:;<=>?@ABA@?>=<;:987654321
                             23456789:;<=>?@ABCDCBA@?>=<;:98765432
                            3456789:;<=>?@ABCDEFEDCBA@?>=<;:9876543
                           456789:;<=>?@ABCDEFGHGFEDCBA@?>=<;:987654
                          56789:;<=>?@ABCDEFGHIJIHGFEDCBA@?>=<;:98765
                         6789:;<=>?@ABCDEFGHIJKLKJIHGFEDCBA@?>=<;:9876
                        789:;<=>?@ABCDEFGHIJKLMNMLKJIHGFEDCBA@?>=<;:987
                       89:;<=>?@ABCDEFGHIJKLMNOPONMLKJIHGFEDCBA@?>=<;:98
                      9:;<=>?@ABCDEFGHIJKLMNOPQRQPONMLKJIHGFEDCBA@?>=<;:9
                     :;<=>?@ABCDEFGHIJKLMNOPQRSTSRQPONMLKJIHGFEDCBA@?>=<;:
                    ;<=>?@ABCDEFGHIJKLMNOPQRSTUVUTSRQPONMLKJIHGFEDCBA@?>=<;
                   <=>?@ABCDEFGHIJKLMNOPQRSTUVWXWVUTSRQPONMLKJIHGFEDCBA@?>=<
                  =>?@ABCDEFGHIJKLMNOPQRSTUVWXYZYXWVUTSRQPONMLKJIHGFEDCBA@?>=
                 >?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\[ZYXWVUTSRQPONMLKJIHGFEDCBA@?>
                ?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^]\[ZYXWVUTSRQPONMLKJIHGFEDCBA@?
               @ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`_^]\[ZYXWVUTSRQPONMLKJIHGFEDCBA@
              ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`aba`_^]\[ZYXWVUTSRQPONMLKJIHGFEDCBA
             BCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdcba`_^]\[ZYXWVUTSRQPONMLKJIHGFEDCB
            CDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefedcba`_^]\[ZYXWVUTSRQPONMLKJIHGFEDC
           DEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghgfedcba`_^]\[ZYXWVUTSRQPONMLKJIHGFED
          EFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijihgfedcba`_^]\[ZYXWVUTSRQPONMLKJIHGFE
         FGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklkjihgfedcba`_^]\[ZYXWVUTSRQPONMLKJIHGF
        GHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnmlkjihgfedcba`_^]\[ZYXWVUTSRQPONMLKJIHG
       HIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnoponmlkjihgfedcba`_^]\[ZYXWVUTSRQPONMLKJIH
      IJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrqponmlkjihgfedcba`_^]\[ZYXWVUTSRQPONMLKJI
     JKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstsrqponmlkjihgfedcba`_^]\[ZYXWVUTSRQPONMLKJ
    KLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvutsrqponmlkjihgfedcba`_^]\[ZYXWVUTSRQPONMLK
   LMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxwvutsrqponmlkjihgfedcba`_^]\[ZYXWVUTSRQPONML
  MNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyzyxwvutsrqponmlkjihgfedcba`_^]\[ZYXWVUTSRQPONM
 NOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|{zyxwvutsrqponmlkjihgfedcba`_^]\[ZYXWVUTSRQPON
OPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~}|{zyxwvutsrqponmlkjihgfedcba`_^]\[ZYXWVUTSRQPO

3
意図的な最初の空白のみの行はありますか?
AdmBorkBork

9
@AdmBorkBorkそれは最初のASCII文字だからスペースですlol
HyperNeutrino

2
@ the4kmanと<=>=<魚。
pizzapants184

4
これに「ASCII Pylonsを構築する必要がある!」というタイトルが付いていない理由はありますか?
mattdm

3
@mattdm私はHNQリストからここに来ただけで、そのタイトルのためにこれを支持しています。よくできました。
トッドウィルコックス

回答:


4

Canvas15 14 バイト

0c[C²[j}¹m]/││

ここで試してみてください!

これを作成している間に、Canvasが以前はASCII / unicodeの組み込みを何も持っていなかったため、いくつかの組み込み()を追加したことに注意してください...

説明(一部の文字は等幅に見えるように置き換えられています):

0c              push the charcode of "0" - 48
  {       ]     map over 1..48
   C              push the ASCII characters
    ²[ ]          repeat by the counter (0-indexed)
      j             remove the last character
        ¹m        mold to the length of the counter
           /    pad each line with spaces so it looks like a diagonal
            ││  palindromize the whole thing horizontally

16

パワーシェル、73バイト

' '*48;46..0|%{" "*$_+-join[char[]](($x=79-$_)..($y=$x+$j++)+(++$y)..$x)}

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

最初の空白のみの行を出力し、から46にループし0ます。各反復では、対応する数のスペースを出力し、いくつかの計算を介して、適切なシンボルの-joined char配列を一緒に出力します。


1
最初の行を47個のスペースとそれに続くスペース文字として扱うことで、いくつかの計算を保存できますか?
ライキング

@Rikingこれを行うには、3つ以上のアイテムではなく1つのアイテムのみを作成するために、char-arrayがどのように作成されるかという特別なケースが必要です。その結果、スペースのみの行を完全に個別に使用する特別な場合よりも短くなります。
AdmBorkBork

11

、13バイト

E⁴⁸⮌✂γι⊕⊗ι‖O←

オンラインでお試しください!リンクは、コードの詳細バージョンです。説明:

 ⁴⁸             Literal 48
E               Map over implicit range
      ι  ι      Current index
        ⊗       Doubled
       ⊕        Incremented
     γ          Printable ASCII
    ✂           Slice
   ⮌            Reverse
                Implicitly print each slice on separate lines
          ‖O←   Reflect with overlap

5
出力は私には間違っているようです。
氏Xcoder

1
@ Mr.Xcoderうーん、古典的なオフバイ1エラー...
ニール

8

Python 2、73バイト

i=48
while i:i-=1;r=range(79-i,127-i*2);print' '*i+bytearray(r+r[-2::-1])

オンラインでお試しください!アナーキーゴルフからクロスポスト(私の投稿を参照)。

迅速な事後分析:xnorとdianneはまったく同じソリューションを発見しました。ebicochnealは、ミッチが70バイトに改善された71バイトのソリューションを提出しました。「現在の行」変数を保持して巧妙に更新することにより、(長い)または(さらに長い)を完全に処理することを避けます。bytearray''.join(map(chr,…))





4

Common Lisp、110バイト

(dotimes(i 48)(dotimes(j 96)(princ(if(>(abs(- j 48))i)" "(code-char(+(-(* i 2)(abs(- j 48)))32)))))(princ"
"))

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

説明

(dotimes(i 48)                   ;; for i from 0 up to 47
    (dotimes(j 96)               ;; for j from 0 up to 95
        (princ                   ;; print
            (if(>(abs(- j 48))i) ;; if abs(j - 48) > i
                " "              ;; print " "
                (code-char(+(-(* i 2)(abs(- j 48)))32)) ;; else print appropriate character
            )
        )
    )(princ"
") ;; print newline
)

3

VBA、71バイト

コンソールへの入力と出力を行わない匿名VBEイミディエイトウィンドウ関数。

For i=0To 47:?Spc(47-i);:For j=-i To i:?Chr(32-Abs(j)+2*i);:Next:?:Next



2

C(gcc)、117バイト

c;i;main(){for(i=0;i<48;++i){for(c=2*i-15;c<32+2*i;++c)putchar(c>31+i?c:32);for(;c>31+i;--c)putchar(c);putchar(10);}}

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

ゴルフをしていない:

int ch;
int row;
int main(void) {
    for (row = 0; row < 48; ++row) {
        for (ch = 2*row-15; ch < 32 + 2*row; ++ch) {
            // The first character in the row is 2*row - 15 (row is zero-indexed)
            if (ch > 31+row)
                putchar(ch);
            else
                // If the current character is not in the pyramid, mask it with a space
                putchar(' ');
        }
        for (; ch > 31+row; --ch) {
            // Finish the other side of the pyramid
            putchar(ch);
        }
        putchar('\n');
    }
}




2

T-SQL、153バイト

DECLARE @ INT=33,@t CHAR(95)=''a:PRINT @t;
SET @t=LEFT(STUFF(STUFF(@t,63-@/2,2,''),46,0,CHAR(@-1)+CHAR(@)+CHAR(@+1)+CHAR(@)),33+@/2)
SET @+=2IF @<128GOTO a

返品は表示専用です。

完全な文字列(163文字)を事前に構築するループや、オンザフライで構築するネストされたループ(168文字)など、いくつかのアイデアを試しましたが、これは最短になりました。

基本的に、各ループは4つの新しい文字を文字列の中心に詰め込みSQL 関数を使用して両端から余分な部分を削除しますSTUFF()

フォーマットおよび説明:

DECLARE @ INT=33,                      --Using a single counter for both rows and CHAR
        @t CHAR(95)=''                 --a non-null CHAR field will pre-fill with spaces
a:                                     --GOTO loop, shorter than a WHILE
    PRINT @t                           --duh
    SET @t = LEFT(                     --lops off the character at the end
            STUFF(                     --crams 4 new characters in the middle
            STUFF(@t, 63-@/2, 2, '')   --snips out a space and the leading character
                 ,46, 0, CHAR(@-1) + CHAR(@) + CHAR(@+1) + CHAR(@))
                 ,33 + @/2)            --rest of the LEFT()
    SET @+=2
IF @<128 GOTO a

2

J47 44バイト

(,.~}:@|."1)(1+i.48)([|.@{.}.)"0 1 u:31+i.96

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

テンプレートを提供してくれたConor O'Brienに感謝します!無効な解決策を示してくれたFrownyFrogに感謝します。


1
おそらく、これはより簡単に変更可能です:オンラインで試してみてください!
コナーオブライエン

@Conor O'Brien-テンプレートをありがとう、リンクを更新しました。
ガレンイワノフ

上部に余分な行を印刷します。
FrownyFrog

@FrownyFrogああ、たった今、先頭の行ではなく、末尾の改行だけが許可されていることがわかりました。私はそれを修正しようとします。
ガレンイワノフ

@FrownyFrog-修正され、わずかにゴルフされました。
ガレンイワノフ

2

ルビー、59バイト

48.times{|i|-47.upto(i){|c|putc~c<i ?32-c.abs+2*i:32};puts}

アナゴルに関する私の答えからクロスポスト。


2

Japt -R18 15バイト

追加の先頭の改行が許可されている場合は14バイト

#0õ_odH+ZÉ ¬êÃû

試して


説明

#0                  :48
  õ                 :Range [1,48]
   _         Ã      :Pass each Z through a function
    o               :  Range [0,Z)
      H+ZÉ          :    To each add 32+Z-1
     d              :    Get the character at that codepoint
           ¬        :  Join to a string
            ê       :  Palinrdomise
              û     :Centre pad each element to the length of the longest element
                    :Implicitly join with newlines and output

2

J 40 37  32バイト

40式 u:30+2>.(+:@i.@(2&+)(-*(>+:))"0 _|@i:)47彼らのソリューションのアイデア+ガレンイワノフ&+コナー・オブライエンのおかげで

37 エコーを含む echo u:32+|.(~.(>:*+:@[-])"0 _])|i:47

echo u:32+|.(~.(>:*[+-)"{])|i:47

コメントから@FrownyFrogのヒントを取り入れる

TIO


表現は有効な投稿だとは思いません。
LyricLy

@LyricLy、意見は今、私は「エコー」を追加するための部屋を持っている..私はこのフォームで別のJの答えを参照してくださいそうであるように変化させるために、他の8つのバイトを剃るために私をつついためとにかくおかげだ:希望あなたしている幸せ:)
jayprich

"0 _"{
FrownyFrog

+:@[-][+-
FrownyFrog

美しい..これらのヒントをありがとう@FrownyFrog
jayprich



1

ルビー、78バイト

s=*32;48.times{puts (s.map(&:chr)*'').center 95;c=*s[0]+1;s=c+s.map{|x|x+2}+c}

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

完全なプログラム。ゴルフをしていない:

s=*32;                              # s is an array of integers
48.times{                           # Repeat 48 times:
  puts (s.map(&:chr)*'').center 95; # Turn each int to a char, join, center, and print
  c = *s[0] + 1;                    # c is a singleton array. It will bookend the next line
  s = c + s.map{|x|x+2} + c         # Add 2 to each element of s before adding the bookends
}





1

Gol><>, 29 bytes

`0FaLssLF:P|LF:M|`/L-R` lRo|;

Try it online!

How it works

`0FaLssLF:P|LF:M|`/L-R` lRo|;

`0F                        |;  Repeat the following 48 times and halt...
   a                           Push 10 (\n)
    Lss                        Push L(loop counter) + 32
       LF:P|                   Repeat "Clone the top and increment" L times
            LF:M|              Repeat "Clone the top and decrement" L times
                 `/L-R`        Push 32 (space) 47-L times (space is significant)
                        lRo    Print everything as char, from the top,
                               until the stack is empty

1

Tcl, 129 122 118 117 bytes

time {incr i;set j -48;set a {};time {set a $a[format %c [expr abs([incr j])>=$i?32:$i*2-abs($j)+30]]} 96;puts $a} 48

Try it online!

Explanation

time { # for i from 0 up to 47
    incr i
    set j -48
    set a {}
    time { # for j from -48 up to 47
        # add next character to a
        set a $a[format %c [expr abs([incr j])>$i?32:$i*2-abs($j)+32]]
    } 96
    puts $a # print a
} 48

1

C (gcc) 199 bytes

#include<stdio.h>
int i,j=32,k=32,l=49;int main(){while(k<127){for(i=0;i<l;++i)printf(" ");for(i=j;i<k;++i)printf("%c",i);printf("%c",k);for(i=k-1;i>=j;--i)printf("%c",i);printf("\n");j++;k+=2;l--;}}

Try it online!

Thanks to Picard and PunPun1000 for all of the help


@Picard I removed the spaces. I could further minify with a global iterator variable.
Jonathan Landrum

@Picard I edited it on my phone; didn't realize I'd left a blank line.
Jonathan Landrum

1
There's unnecessary spaces in the printf calls after the commas, and the variable names can be shortened down to one letter. Also it would be nice if you could include a TIO link and the actual byte count. Here's the link for your current code TIO
PunPun1000

ok, i've squeezed it a bit more, i think i'd have to change the algorithm to shrink it further
Jonathan Landrum

1

Haskell, 102 bytes

main=putStr$do
i<-[48,47..0]
let l=replicate i 32++[79-i..126-i*2]
map toEnum$l++tail(reverse l)++[10]

Things I have tried that were not shorter:

  • Expressing everything in terms of character literals and succ or pred to save the map toEnum.
  • Writing a downward range instead of using reverse.
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.