トランプが壁を築くのを助けてください!


68

トランプは壁を構築する必要があり、あなたはそれをするつもりです!彼の壁を最も効率的に構築するために、使用できるシンプルで繰り返し可能なパターンを作成しました。

    __   __    
   |  |_|  |   
___|       |___
-   -   -   -  
 - - - - - - - 
- - - - - - - -
———————————————

トランプは、彼が必要とする壁セグメントの数を教えてくれます。そして、あなたはそれらをちょうどこのように構築します。

パターンは次のとおりです。

    __   __     <-- 4-2-3-2-4          ' _ _ '
   |  |_|  |    <-- 3-1-2-1-1-1-2-1-3  ' | |_| | '
___|       |___ <-- 3-1-7-1-3          '_| |_'
-   -   -   -   <-- 1-3-1-3-1-3-1-1    '- - - - '
 - - - - - - -  <-- 1-1-...-1-1        ' - -...- - '
- - - - - - - - <-- 1-1-...-1-1        '- - ... - -'
——————————————— <-- 15                 Unicode U+2014

入力は常に整数> 0です。

テストケース:

1
    __   __    
   |  |_|  |   
___|       |___
-   -   -   -  
 - - - - - - - 
- - - - - - - -
———————————————

2
    __   __        __   __    
   |  |_|  |      |  |_|  |   
___|       |______|       |___
-   -   -   -  -   -   -   -  
 - - - - - - -  - - - - - - - 
- - - - - - - -- - - - - - - -
——————————————————————————————

5
    __   __        __   __        __   __        __   __        __   __
   |  |_|  |      |  |_|  |      |  |_|  |      |  |_|  |      |  |_|  |
___|       |______|       |______|       |______|       |______|       |___
-   -   -   -  -   -   -   -  -   -   -   -  -   -   -   -  -   -   -   -
 - - - - - - -  - - - - - - -  - - - - - - -  - - - - - - -  - - - - - - - 
- - - - - - - -- - - - - - - -- - - - - - - -- - - - - - - -- - - - - - - -
———————————————————————————————————————————————————————————————————————————

これを高速で行う必要があるため、できるだけ短いプログラムを作成してください。

それが役立つ場合は、最初にチャレンジを書き、タイトルを最後に書きました;)

回答:


9

05AB1E、38バイト

•4H’*»È%f·ù„áÅ'4•4B3ÝJ"_ -|"‡8ô€ûvy¹×»

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

•4H’*»È%f·ù„áÅ'4•     # Push '1724427993555739020619095486300160'
4B                    # Convert to base 4 (turns it into an 8x8 bitmap).
  3ÝJ"_ -|"‡          # Replace digits 0-3 with _, , -, or |.
            8ô        # Split into pieces of 8.
              €û      # Palindromize each piece.
                vy¹×» # For each row, dupe it n times (hori) and print it.

1724427993555739020619095486300160を基数4に変換:

11110011111311300003111121112111121212122121212100000000

11110011111311300003111121112111121212122121212100000000の文字が置き換えられました:

__ | |____| - - - - - -- - - - ________

8個に分割された以前のパターン:

    __  
   |  |_
___|    
-   -   
 - - - -
- - - - 
________

次に回文を回し、必要なだけ繰り返します。


29

CJam、52バイト

F,ri*"s@;b6(MBZF,fu"128b6b"_ 
|-—"f=N/ff=zN*

印刷できないASCII文字の束が含まれています。プッシュされる最初の文字列リテラルのhexdumpは次のとおりです。

01 73 06 40 3B 62 36 28 1E 4D 07 42 5A 14 1B 46 2C 66 75

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

説明

上記のhexdumpはベース128の数値として解釈され、ベース6に変換されてこのリストを取得します。

[1 1 1 1 0 0 1 1 1 0 0 2
 1 1 1 3 1 1 3 0 3 1 1 3 2
 0 0 0 3 1 1 1 1 1 1 1 3 2
 4 1 1 1 2
 1 4 2
 4 1 2
 5]

このために、我々はマッピングを適用します0 → _1 → space2 → \n3 → |4 → -5 → —。これにより文字列が取得されます。

    __   __
   |  |_|  |
___|       |
-   
 -
- 
—

各行の「期間」で構成されます。すなわち、5行目を循環して" -"を取得でき" - - - - - - - "ます。

次に、このサブプログラムを実行します。

N/               Split into lines.
  Ff*            Repeat each line 15 times (to cycle it).
     Ff<         Take the first 15 chars of each line.
        rif*     Repeat these chars input() times.
            N*   Join lines.

(新しいバージョンはこれをやや異なる方法で実行しますが、実際にはを使用してff=いるため、自分の頭をあまりうまくラップできません。)


21
これは私がいなくても何です
コナー・オブライエン

4
この言語はこの答えのために特別に作られたのですか?
Erdal G.

5
@ErdalG。いいえ。CJamはPPCGレギュラー(aditsu)によって実際に作成されましたが、かなり前から存在しています。あなたはサイト全体にそれを見つけるでしょう。:)
アレックスA.

@AlexA。わかりました。私はここでかなり新しいです、ありがとう!:)
Erdal G.

@ErdalG。どういたしまして。サイトへようこそ!
アレックスA.

13

JavaScript(ES6)、116 115バイト

n=>"__   __    n|  |_|  |   n|       |___n -  n- n -n—".split`n`.map(l=>l.repeat(15).slice(-15).repeat(n)).join`
`

@Neilのおかげで1バイト節約できました

説明

@MaurisのCJamメソッドとほとんど同じですが、文字マッピングはありません。

壁のパーツの形式は次のとおりです。

__   __    
|  |_|  |   
|       |___
 -  
- 
 -
—

各行を15回繰り返すと、次のようになります。

...    __   __    __   __    __   __    
... |  |_|  |   |  |_|  |   |  |_|  |   
... |       |___|       |___|       |___
 -   -   -   -   -   -   -   -   -   -  
          - - - - - - - - - - - - - - - 
           - - - - - - - - - - - - - - -
                         ———————————————

最後の15文字にスライスした後、次のようになります。

    __   __    
   |  |_|  |   
___|       |___
-   -   -   -  
 - - - - - - - 
- - - - - - - -
———————————————

非ゴルフ

n=>

  // array of wall line parts
  "__   __    n|  |_|  |   n|       |___n -  n- n -n—".split`n`

  .map(l=>       // for each wall line
    l.repeat(15) // repeat the line 15 times to create a complete wall line
    .slice(-15)  // each wall piece is only 15 characters long
    .repeat(n)   // repeat the wall n times
  )
  .join`
`                // output the resulting wall

テスト


.slice(-15)代わりに使用してバイトを保存できますか?
ニール

修正は簡単です。左の最小部分の代わりに右の最小部分を使用するだけです:__ __ n| |_| | n| |___n - n- n -n—
ニール

非常に賢い、素晴らしい仕事です!
Jアトキン

@ニールああ、あなたは正しい。ヒントをありがとう!
user81655

5

Jolf、135バイト

かなりのゴルフができます。より良い結果を得るには、きれいな印刷をオフにして出力をクリアします。ここで試してみてください!。また、これを使用て任意の数をより簡単にテストできます。

oHpAt++++++++++++*"    __   __    "jH*"   |  |_|  |   "jH*"___|       |___"jH*j"-   -   -   -  "H*+*" -"7' jH*"- - - - - - - -"jH*M35j'—

後で説明を追加します。


6
@コナー・オブライエンだから、その説明でどのように見えるイータは何ですか:D
Rohan Jhunjhunwala

5

ハスケル、116の 118 108バイト

h n=take(n*15).cycle
f n=unlines$h n.h 1<$>lines"    __   __\n   |  |_|  |\n___|       |\n-   \n -\n- \n—"

使用例:

*Main> putStr $ f 3
    __   __        __   __        __   __    
   |  |_|  |      |  |_|  |      |  |_|  |   
___|       |______|       |______|       |___
-   -   -   -  -   -   -   -  -   -   -   -  
 - - - - - - -  - - - - - - -  - - - - - - - 
- - - - - - - -- - - - - - - -- - - - - - - -
—————————————————————————————————————————————

ここでは、他の回答と同じ戦略を使用します。壁の各行はパターンの1サイクルです。たとえば、最後の2行目の「-」(ダッシュ+スペース)です。各パターンを繰り返し、一方の壁セグメントを取得し、再び繰り返して取る15個の文字を取る15*nための文字をnセグメント。

編集:@Maurisは10バイトを見つけました。ありがとう!


一番下の行は—(U + 2014)であり、ASCIIダッシュではありません。これは、2バイトを失うことを意味すると思います。
リン

@モーリス:そのとおりです。それを修正しました。見つけてくれてありがとう。
nimi

実際には、行1〜3のピリオドをより早く終了して、4 + 3 + 3バイトを節約できます。(私のCJamの答えは同じことをします。)
リン

@Mauris:ああ、そうです。最初のサイクルは15文字後に切断されます。ありがとう!
nimi

4

Bash + Linuxユーティリティ(247 186 180バイト)

read x
for i in {1..7}
do
tail -n +7 $0|gzip -dc|sed -nr "$i s/(.*)/$(printf '\\1%.0s' $(seq 1 $x))/p"
done
exit
ˈ ELzVSPPPȏǑ
\@\D񵠚k>ĄÚ ܋ɀÜ@r²uٞ5L! 󰰹͠  

印刷できない文字は上記のスクリプトの作成にgeneしみなく使用されているため、ここにhexdumpがあります。

00000000  72 65 61 64 20 78 0a 66  6f 72 20 69 20 69 6e 20  |read x.for i in |
00000010  7b 31 2e 2e 37 7d 0a 64  6f 0a 74 61 69 6c 20 2d  |{1..7}.do.tail -|
00000020  6e 20 2b 37 20 24 30 7c  67 7a 69 70 20 2d 64 63  |n +7 $0|gzip -dc|
00000030  7c 73 65 64 20 2d 6e 72  20 22 24 69 20 73 2f 28  ||sed -nr "$i s/(|
00000040  2e 2a 29 2f 24 28 70 72  69 6e 74 66 20 27 5c 5c  |.*)/$(printf '\\|
00000050  31 25 2e 30 73 27 20 24  28 73 65 71 20 31 20 24  |1%.0s' $(seq 1 $|
00000060  78 29 29 2f 70 22 0a 64  6f 6e 65 0a 65 78 69 74  |x))/p".done.exit|
00000070  0a 1f 8b 08 00 45 4c 7a  56 02 03 53 50 50 50 88  |.....ELzV..SPPP.|
00000080  8f 87 11 0a 5c 40 5c 03  44 f1 35 60 5a 81 2b 3e  |....\@\.D.5`Z.+>|
00000090  1e c4 04 83 1a 20 9b 4b  17 c8 40 c2 5c 40 02 19  |..... .K..@.\@..|
000000a0  72 a1 72 75 b9 1e 35 4c  21 1e 01 00 f3 30 f0 f9  |r.ru..5L!....0..|
000000b0  8d 00 00 00                                       |....|
000000b4

4

PowerShell、103 100文字(ディスク上で105バイト、BOMなしの102)

@ user81655 methodとほぼ同じです。

Param($c)'    __   __n   |  |_|  |n___|       |n-   n -n- n—'-split'n'|%{($_*15).Substring(0,15)*$c}

ゴルフされていないバージョン

# Assign input to variable,
Param($c)

# Split array of wall parts and send them down the pipeline
'    __   __n   |  |_|  |n___|       |n-   n -n- n—' -split 'n' |
    ForEach-Object { # For each piece of wall
        ($_*15) # Repeat the line 15 times to create a complete wall line
        .Substring(0,15) # Each wall piece is only 15 characters long
        *$c # Repeat the wall n times
    }

使用例

PS> .\TrumpWall.ps1 3
    __   __        __   __        __   __    
   |  |_|  |      |  |_|  |      |  |_|  |   
___|       |______|       |______|       |___
-   -   -   -  -   -   -   -  -   -   -   -  
 - - - - - - -  - - - - - - -  - - - - - - - 
- - - - - - - -- - - - - - - -- - - - - - - -
—————————————————————————————————————————————

1
97バイト:param($c);' __ __n | |_| |n___| |n- n -n- n—'-split'n'|%{-join($_*15)[0..14]*$c}
mazzy

4

PHP 5.4、(182175文字)

foreach(['    __   __    ','   |  |_|  |   ','___|       |___','-   -   -   -  ', ' - - - - - - - ','- - - - - - - -','———————————————'] as$d)echo str_repeat($d,$argv[1])."\n";

非ゴルフバージョン

$s=['    __   __    ',
    '   |  |_|  |   ',
    '___|       |___',
    '-   -   -   -  ',
    ' - - - - - - - ',
    '- - - - - - - -',
    '———————————————'
];
foreach($s as $d) {
    echo str_repeat($d,$argv[1])."\n";
}

[Blackholeの提案に従って7文字が保存されました。]

バイト数は少ないが文字数が多い別のバージョン

PHP 5.4、(176文字、178バイト)

foreach(['    __   __    ','   |  |_|  |   ','___|       |___','-   -   -   -  ',' - - - - - - - ','- - - - - - - -',str_repeat('—',15)] as$d)echo str_repeat($d,$argv[1])."\n";

str_repeat関数を使用して、15個のm-dashのインスタンスを1個のダッシュに置き換えるだけです。


2
1)のための変数を定義しないでください$s:あなたのループ内で直接それを使用する、foreach([…,…] as $d)前の2)しない限り、スペースを削除$dforeach(… as$d)3)の代わりに、改行を使用してください"\n"
ブラックホール

あなたは真実を描写していません。コードは182文字ですが、212バイトです。
Tschallacka

、文字対バイト程度、申し訳ありませんが混乱して修正@MichaelDibbets
kuldeep.kamboj

1
以下のようなものを使用mothereff.in/byte-counterをバイトカウントする
Tschallacka

3

C、148バイト

#define q 16843009
i;p[]={-1,q*17,q*68,q*16,-8388417,8577152,3936000};
f(n){for(i=n*105;i--;i%(15*n)||puts(""))putchar(" -|_"[p[i/15/n]>>i%15*2&3]);}

スコアは、f(n)明確にするために前に含まれる不要な改行を除外します。

のマジックナンバーはpそれぞれ文字列0,1,2,3から再構築されたベース4の壁の文字をエンコードし" -|_" ます

1684300916進数は0x1010101です。これは-、それらに含まれる行に使用されます。

ため_によりコードされ3、一番下の行は、単にとして符号化することが可能-1に設定されたすべてのビットの数です、1


いいですが#define q、値を使用せずにハードコーディングするだけで3バイト節約できます。
ヨハンデュトワ

2

Vitsy、121バイト

これを行うには、入力時に一度に1行ずつ各行にアクセスし、各行の内容をスタックに格納します。次に、1行ずつ出力します。誰かが私にもっと詳細な説明をしてほしいと思ったら、尋ねてください(私は現在プレゼントを開いているので...)。

V0v7\[v1+v&V\[vDvm]a]y\[?Z]
"    __   __    "
"   |  |_|  |   "
"___|       |___"
4\["-   "]Xr
6mXr" "
8\["- "]X
"—"e\D

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


2

PHP5.5、182の 172バイト 168のバイト

@ kuldeep.kambojの回答に基づいています。これは実際にこれを書いた時点では212バイトですが、182文字です。壁が少し高くなればいいのですが、さらに最適化を行うことができます;-)

これは@JörgHülsermannのおかげで168バイトです

$r='str_repeat';$d=$r(' -',7);$x='   ';foreach(["$x __   __ $x","$x|  |_|  |$x","___|$x$x |___","-$x-$x-$x-  ","$d ","-$d",$r('—',15)] as$z){echo$r($z,$argv[1])."
";}

これは172バイトです

$r='str_repeat';$d=$r(' -',7);$x=$r(' ',3);foreach(["$x __   __ $x","$x|  |_|  |$x","___|$x$x |___","-$x-$x-$x-  ","$d ","-$d",$r('—',15)] as$z){echo$r($z,$argv[1])."
";}

これは182バイトです:-)

$r='str_repeat';$d=$r(' -',7);$x=$r(' ',4);foreach([$x.'__   __'.$x,'   |  |_|  |   ','___|       |___','-   -   -   -  ',$d.' ','-'.$d,$r('—',15)] as$z){echo $r($z,$argv[1]).'
';}

無償版

$r='str_repeat';
$d=$r(' -',7);
$x=$r(' ',3);
$s=["$x __   __ $x",
    "$x|  |_|  |$x",
    "___|$x$x |___",
    "-$x-$x-$x-  ",
    "$d ",
    "-$d",
    $r('—',15)
];
foreach($s as $z) {
  echo$r($z,$argv[1])."
";
}

以前のようにスペースを削除し、ブラケットを取り外し-3バイト
イェルクHülsermann

$x=$r(' ',3);短縮することができます$x=' ';
ヨルクヒュルサーマン

$ z`のように書くことができるようあなたは`foreachループのためのブラケットを必要としませんas$z
イェルクHülsermann

2

Python 3、132 122 120バイト

def f(n):[print((s*15*n)[:15*n])for s in['    __   __    ','   |  |_|  |   ','___|       |___','-   ', ' -', '- ', '—']]

ゴルフをしていない:

def f(n):
    [print((s*15*n)[:15*n])for s in['    __   __    ',
                                    '   |  |_|  |   ',
                                    '___|       |___',
                                    '-   ',
                                    ' -',
                                    '- ',
                                    '—']]

取得するスペースを削除することができ)for s in[ます
...-チョイス

2

Python 2(161文字、191バイト)

x=input();a=['    __   __    ','   |  |_|  |   ','___|       |___','-   -   -   -  ',' - - - - - - - ','- - - - - - - -','———————————————']
for i in a:print i*x

2

SOGL V0.12、32のバイト

→↔\ιδ»►℮⁰}▒║ΙOģΠp~⁵‘ ¾“ζ'¹*+'¹n*

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

説明:

...‘ ¾“ζ'¹*+'¹n*
...‘              push a string of the top 6 lines of 1 wall piece (no newlines)
     ¾“           push 8212
       ζ          convert to char from unicode codepoint
        '¹*       repeat 15 times
           +      add that to the previous compressed string
            '¹n   split into lines with length 15
               *  repeat horizontally input times

すべてのアスキーアートの質問に戻り、いくつかの点でSOGLで文字通りそれらのすべてを私を打つためdzamiaをupvotes
マジックタコ壺を

1

Vim、90キー

入力が単独でバッファにあると仮定すると、次のようになります(読みやすくするために改行のみ)

"aDi    __   __    ^M   |  |_|  |   ^M___|       |___^M^[
4i-   ^[xo-^[Y7P8JY2PxA ^[GVr^K-M^Vgg$d@aP

どこ^Mreturn^[escape^Kであるctrl+k^Vされますctrl+v

パターンを生成するためのより良い方法があるかもしれないので、これは非常に多くの可能性があります。


0

Java 11、236 235 231 229バイト

n->{String w[]={"","","","","","",""},t="- ".repeat(7);for(;n-->0;w[0]+="x __x__x ",w[1]+="x|  |_|  |x",w[2]+="___|xx |___",w[3]+="-x-x-x-  ",w[4]+=" "+t,w[5]+=t+"-")w[6]+="_".repeat(15);return"".join("\n",w).replace("x","   ");}

オンラインでお試しください。
注:Java 11はまだTIO上にないためString.repeat(int)repeat(String,int)(同じバイト数で)エミュレートされています。

説明:

n->{                                // Method with integer parameter and String return-type
  String w[]={"","","","","","",""},//  Start with seven empty rows
         t="- ".repeat(7);          //  Temp String to reduce bytes
  for(;n-->0;                       //  Loop `n` amount of times:
    w[0]+="x __x__x ",              //   Append to the first row
    w[1]+="x|  |_|  |x",            //   Append to the second row
    w[2]+="___|xx |___",            //   Append to the third row
    w[3]+="-x-x-x-  ",              //   Append to the fourth row
    w[4]+=" "+t,                    //   Append to the fifth row
    w[5]+=t+"-")                    //   Append to the sixth row
    w[6]+="_".repeat(15);           //   Append to the seventh row
  return"".join("\n",w)             //  Join all rows by new-lines
          .replace("x","   ");}     //  Then replace all "x" with three spaces,
                                    //  and return the result

0

Powershell +ファイル、92バイト

powershellをget-trumpwall.ps1(40バイト)節約します

param($c);gc f|%{-join($_*15)[0..14]*$c}

名前付きのデータファイルを保存し、fUnicodeシンボルとLinux LFのみを含むデータ(52バイト):

    __   __
   |  |_|  |
___|       |
-   
 -
- 
—

16進ダンプ:

0000000000: 20 20 20 20 5F 5F 20 20 │ 20 5F 5F 0A 20 20 20 7C      __   __◙   |
0000000010: 20 20 7C 5F 7C 20 20 7C │ 0A 5F 5F 5F 7C 20 20 20    |_|  |◙___|
0000000020: 20 20 20 20 7C 0A 2D 20 │ 20 20 0A 20 2D 0A 2D 20      |◙-   ◙ -◙-
0000000030: 0A E2 80 94             │                          ◙—››

使用例

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