Pomóż Trumpowi zbudować ścianę!

68

Trump potrzebuje zbudowanej ściany, a ty to zrobisz! Aby najskuteczniej zbudować jego ścianę, stworzyłem prosty, powtarzalny wzór do użycia:

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

Trump powie ci, ile segmentów ściany potrzebuje, a ty zbudujesz je tak, by wyglądały właśnie tak.

Oto wzór:

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

Dane wejściowe zawsze będą liczbą całkowitą> 0.

Przypadki testowe:

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

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

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

Ponieważ musisz to zrobić szybko, napisz jak najkrótszy program!

Jeśli to pomoże, najpierw napisałem wyzwanie, ostatni tytuł;)

J Atkin
źródło

Odpowiedzi:

9

05AB1E , 38 bajtów

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

Wypróbuj online!

•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 przekonwertowany na base-4:

11110011111311300003111121112111121212122121212100000000

11110011111311300003111121112111121212122121212100000000 z zastąpionymi znakami:

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

Poprzedni wzór podzielony na 8 części:

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

Następnie palindromujesz i powtarzasz tak długo, jak to konieczne.

Urna Magicznej Ośmiornicy
źródło
29

CJam, 52 bajty

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

Zawiera grupę niezadrukowanych znaków ASCII. Zrzut heksowy pierwszego wypisanego dosłownego ciągu znaków to:

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

Wypróbuj tutaj!

Wyjaśnienie

Powyższy zrzut heksowy jest interpretowany jako liczba base-128, a następnie konwertowana na base 6, aby uzyskać tę listę:

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

W tym celu stosujemy mapowanie 0 → _, 1 → space, 2 → \n, 3 → |, 4 → -, 5 → —. To daje nam ciąg:

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

Składa się z „okresu” każdej linii; tzn. możemy przejechać piątą linię, " -"aby uzyskać " - - - - - - - ".

Następnie wykonujemy ten podprogram:

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.

(Nowa wersja robi to w nieco inny sposób, tak naprawdę nie jestem w stanie dobrze owinąć głowy, ponieważ używa ff=).

Lynn
źródło
21
Czego to nawet nie robię
Conor O'Brien
4
Czy ten język został stworzony specjalnie dla tej odpowiedzi?
Erdal G.,
5
@ErdalG. Nie. Chociaż CJam został stworzony przez zwykłego PPCG ( aditsu ), istnieje już od dłuższego czasu. Znajdziesz to na całej stronie. :)
Alex A.
@AlexA. Ok, teraz masz więcej sensu. Jestem tu całkiem nowy, dzięki! :)
Erdal G.
@ErdalG. Moja przyjemność. Witamy na stronie!
Alex A.,
13

JavaScript (ES6), 116 115 bajtów

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

Zapisano bajt dzięki @Neil !

Wyjaśnienie

Prawie taka sama jak metoda CJam @Mauris , ale bez mapowania znaków.

Części ścienne mają format:

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

ponieważ jeśli powtórzysz każdą linię 15 razy, otrzymasz:

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

a po pocięciu na ostatnie 15 znaków otrzymasz:

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

Nie golfił

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

Test

użytkownik 81655
źródło
Czy możesz zapisać bajt, używając .slice(-15)zamiast tego?
Neil,
Naprawienie jest łatwe, wystarczy użyć prawej minimalnej części zamiast lewej minimalnej części:__ __ n| |_| | n| |___n - n- n -n—
Neil
Bardzo sprytna, fajna robota!
J Atkin
@Neil Ah, masz rację. Dzięki za wskazówkę!
user81655,
5

Jolf , 135 bajtów

Można grać w golfa. Wyłącz ładny wydruk i wyczyść wydruk, aby uzyskać lepszy wynik. Wypróbuj tutaj! . Użyj tego również do łatwiejszego testowania dowolnej liczby.

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

Wyjaśnię później.

Conor O'Brien
źródło
6
@Connor O'Brien, więc jak wygląda eta na tym wyjaśnieniu: D
Rohan Jhunjhunwala
5

Haskell, 116 118 108 bajtów

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

Przykład użycia:

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

Wykorzystuje tę samą strategię, co inne odpowiedzi tutaj: każda linia ściany jest jednym cyklem wzoru, np. „-” (myślnik + spacja) dla drugiej ostatniej linii. Powtórz każdy wzór, weź 15 znaków, aby uzyskać jeden segment ściany, powtórz ponownie i weź 15*nznaki dla nsegmentów.

Edycja: @ Mauris znalazł 10 bajtów. Dzięki!

nimi
źródło
Najważniejsze powinno być - (U + 2014), a nie myślnik ASCII; Myślę, że to oznacza, że ​​tracisz 2 bajty.
Lynn
@Mauris: masz rację. Naprawione. Dzięki za informację.
nimi
Możesz faktycznie zakończyć okresy dla linii 1-3 wcześniej, oszczędzając 4 + 3 + 3 bajty. (Moja odpowiedź na CJam robi to samo.)
Lynn
@ Mauris: ah tak, ponieważ pierwszy cykl jest przerywany po 15 znakach. Dzięki!
nimi
4

Narzędzia Bash + Linux ( 247 186 180 bajtów)

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! 󰰹͠  

Ponieważ znaki niedrukowalne zostały szeroko wykorzystane w konstrukcji powyższego skryptu, oto zrzut heksowy:

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
user2064000
źródło
4

PowerShell, 103 100 znaków (105 bajtów na dysku, 102 bez BOM)

Prawie taka sama jak metoda @ user81655 .

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

Wersja bez golfa

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

Przykład użycia

PS> .\TrumpWall.ps1 3
    __   __        __   __        __   __    
   |  |_|  |      |  |_|  |      |  |_|  |   
___|       |______|       |______|       |___
-   -   -   -  -   -   -   -  -   -   -   -  
 - - - - - - -  - - - - - - -  - - - - - - - 
- - - - - - - -- - - - - - - -- - - - - - - -
—————————————————————————————————————————————
beatcracker
źródło
1
97 bajtów:param($c);' __ __n | |_| |n___| |n- n -n- n—'-split'n'|%{-join($_*15)[0..14]*$c}
mazzy
4

PHP 5.4, ( 182 175 znaków)

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

Wersja bez golfa

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

[7 znaków zapisanych zgodnie z sugestią Blackhole. ]

Kolejna wersja z mniejszą liczbą bajtów, ale większą liczbą znaków

PHP 5.4, (176 znaków, 178 bajtów)

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

Wystarczy zastąpić 15 wystąpień m-dash jednym myślnikiem z funkcją str_repeat

kuldeep.kamboj
źródło
2
1) Nie definiuj zmiennej $s, użyj jej bezpośrednio w swojej pętli: foreach([…,…] as $d)2) Usuń wcześniej spację, chyba że $d: foreach(… as$d)3) Użyj nowej linii zamiast "\n".
Blackhole,
Pan nie przedstawia prawdy. Twój kod ma 182 znaki, ale 212 bajtów.
Tschallacka
@MichaelDibbets, Przepraszam, myliłem się co do bajtów vs znaków, zmodyfikowano
kuldeep.kamboj
1
użyj czegoś takiego jak mothereff.in/byte-counter, aby policzyć bajty
Tschallacka
3

C, 148 bajtów

#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]);}

Wynik wyklucza niepotrzebną nową linię, przed f(n)którą uwzględniono ją dla zachowania przejrzystości.

magiczne liczby w pkodują znaki ściany w podstawie 4, które są zrekonstruowane odpowiednio z ciągu " -|_" 0,1,2,3

16843009w hex jest 0x1010101. służy to do linii z -nimi.

Ponieważ _kodowany jest przez 3, dolną linię można zakodować po prostu jako -1, czyli liczbę z ustawionymi wszystkimi bitami 1.

Level River St
źródło
Fajnie, ale możesz zaoszczędzić 3 bajty, nie używając #define qi po prostu zapisując wartości na stałe.
Johan du Toit
2

Vitsy , 121 bajtów

To, jak to robię, polega na uzyskiwaniu dostępu do każdej linii po jednym czasie wprowadzania danych, co daje mi stosy z zawartością każdej linii. Następnie wyprowadzam linię na raz. Jeśli ktoś chce, żebym udzielił bardziej szczegółowych wyjaśnień, po prostu zapytaj (obecnie otwieram prezenty, więc ...).

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

Wypróbuj online!

Dam Son
źródło
2

PHP 5.5, 182 172 bajty 168 bajtów

na podstawie odpowiedzi @ kuldeep.kamboj, która w chwili pisania tego tekstu wynosi 212 bajtów, ale 182 znaki. Chciałbym, żeby ściana była nieco wyższa, więc mogłabym jeszcze trochę zoptymalizować ;-)

ten ma 168 bajtów, dzięki @ JörgHülsermann

$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])."
";}

Ten ma 172 bajty

$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])."
";}

Ten ma 182 bajty :-)

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

wersja bez golfa

$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])."
";
}
Tschallacka
źródło
usuń spację przed
znakiem
$x=$r(' ',3);można skrócić do$x=' ';
Jörg Hülsermann
Nie potrzebujesz nawiasów dla pętli foreach i „as $ z” mógłby napisać jakoas$z
Jörg Hülsermann
2

Python 3, 132 122 120 bajtów

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

Nie golfowany:

def f(n):
    [print((s*15*n)[:15*n])for s in['    __   __    ',
                                    '   |  |_|  |   ',
                                    '___|       |___',
                                    '-   ',
                                    ' -',
                                    '- ',
                                    '—']]
Zenadix
źródło
Możesz usunąć spacje, aby uzyskać )for s in[...
Cyoce
2

Python 2, (161 znaków, 191 bajtów)

x=input();a=['    __   __    ','   |  |_|  |   ','___|       |___','-   -   -   -  ',' - - - - - - - ','- - - - - - - -','———————————————']
for i in a:print i*x
Cplusplusplus
źródło
2

SOGL V0.12 , 32 bajty

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

Wypróbuj tutaj!

Wyjaśnienie:

...‘ ¾“ζ'¹*+'¹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
dzaima
źródło
wraca do wszystkich ascii-artystycznych pytań i głosuje dzamia za pokonanie mnie dosłownie wszystkimi z SOGL w pewnym momencie
Magic Octopus Urn
1

Vim, 90 klawiszy

Zakładając, że dane wejściowe są same w buforze, następujące zadanie wykona zadanie (nowa linia tylko dla czytelności)

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

gdzie ^Mjest return, ^[jest escape, ^Kjest ctrl+ki ^Vjest ctrl+v.

Prawdopodobnie można to nieco pograć w golfa, ponieważ mogą istnieć znacznie lepsze sposoby generowania wzoru.

algmyr
źródło
0

Java 11, 236 235 231 229 bajtów

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","   ");}

Wypróbuj online.
UWAGA: Java 11 nie jest jeszcze w TIO, więc String.repeat(int)została emulowana za pomocą repeat(String,int)(dla tej samej liczby bajtów).

Wyjaśnienie:

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
Kevin Cruijssen
źródło
0

Plik PowerShell + 92 bajty

zapisz PowerShell do get-trumpwall.ps1(40 bajtów)

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

zapisz plik danych z nazwą fi danymi zawiera symbol Unicode i tylko Linux LF (52 bajty):

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

zrzut heksowy:

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             │                          ◙—››

Przykład użycia

PS> .\get-trumpwall.ps1 5
    __   __        __   __        __   __        __   __        __   __
   |  |_|  |      |  |_|  |      |  |_|  |      |  |_|  |      |  |_|  |
___|       |______|       |______|       |______|       |______|       |___
-   -   -   -  -   -   -   -  -   -   -   -  -   -   -   -  -   -   -   -
 - - - - - - -  - - - - - - -  - - - - - - -  - - - - - - -  - - - - - - -
- - - - - - - -- - - - - - - -- - - - - - - -- - - - - - - -- - - - - - - -
———————————————————————————————————————————————————————————————————————————
mazzy
źródło