Ви повинні побудувати пілони ASCII!


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 char lol
HyperNeutrino,

2
@ the4kman і <=>=<риба.
pizzapants184

4
Чи є причина, що це не має назви "Ви повинні побудувати пілони ASCII!"?
mattdm

3
@mattdm Я прийшов сюди лише зі списку HNQ, щоб підтвердити це через свою назву. Чудово зроблено.
Тодд Вілкокс

Відповіді:


4

Полотно , 15 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

PowerShell , 73 байти

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

Спробуйте в Інтернеті!

Виводить перший рядок, який містить лише пробіл, а потім петлі від 46до 0. Кожна ітерація виводить відповідну кількість пробілів, а потім -joinразом - charряд відповідних символів за допомогою деяких обчислень.


1
Чи можете ви зберегти деякі обчислення, обробляючи перший рядок як 47 пробілів, а потім пробіл?
Рікінг

@Riking Для цього вам знадобиться окремий випадок, як створено масив char, щоб створити лише один елемент замість 3 або більше. Як наслідок, коротше, щоб окремий регістр лінії, лише для пробілів, був коротше окремо.
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 Цьфу, класична помилка поза увагою ...
Ніл

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 представив 71-байтний розчин, який мітч покращився до 70 байт . Вони уникають повної роботи bytearray(яка довга) або ''.join(map(chr,…))(що навіть довше) цілком, зберігаючи змінну "поточний рядок" та вміло її оновлюючи.





4

Лист звичайний , 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

J , 47 44 байт

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

Спробуйте в Інтернеті!

Дякуємо Conor O'Brien за шаблон! Дякуємо FrownyFrog за вказівку недійсного рішення.


1
Можливо, це легше змінити: спробуйте в Інтернеті!
Conor O'Brien

@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 -R, 18 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 підказки з коментарів

ТІО


Я не думаю, що висловлювання є дійсними поданнями.
LyricLy

@LyricLy, думка, схоже, змінюється, оскільки я бачу ще одну відповідь J у цій формі .. все одно дякую, що запропонували мені голити ще 8 байт .. тепер у мене є місце додати "ехо": сподіваюся, ти щасливий
:)

"0 _"{
FrownyFrog

+:@[-][+-
FrownyFrog

красиво .. дякую за ці поради @FrownyFrog
jayprich


1

Python 2 , 98 88 байт

-1 байт завдяки @ Mr.Xcoder

i=32
exec"print''.join(chr(i+i-32-abs(j))for j in range(32-i,i-31)).center(95);i+=1;"*48

Спробуйте в Інтернеті!


-i+32=> 32-iі ви можете використовувати ' '*(79-i)замість того, .center(95)щоб зберегти байти.
Містер Xcoder

@ Mr.Xcoder дякую! ' '*(79-i)+насправді не економить байти: D
Dead Possum

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

МОЙ-ОСНОВНИЙ , 97 байт

Анонімний MY-BASIC відповідь, який не приймає вводу та виводить на консоль

For i=0 To 47
For j=i To 47
Print" "
Next
For j=-i To i
Print Chr(32-Abs(j)+2*i)
Next
Print;
Next

Спробуйте в Інтернеті!

-1 байт завдяки Джонатану Фреху


1
Print " "-> Print" ".
Джонатан Фрех

@JonathanFrech - да, вибачте, що я збив ваше ім'я
Тейлор Скотт


1

Гол> <> , 29 байт

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

Спробуйте в Інтернеті!

Як це працює

`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 байт

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

Спробуйте в Інтернеті!

Пояснення

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 байт

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

Спробуйте в Інтернеті!

Дякуємо Picard та PunPun1000 за всю допомогу


@Picard Я видалив пробіли. Я можу додатково змінити глобальну змінну ітератора.
Джонатан Ландрум

@Picard я відредагував це на своєму телефоні; не зрозумів, що я залишив порожній рядок.
Джонатан Ландрум

1
У викликах printf після коми немає зайвих пробілів, а назви змінних можна скоротити до однієї літери. Також було б непогано, якщо ви могли б включити посилання TIO та фактичний кількість байтів. Ось посилання на ваш поточний код TIO
PunPun1000

ок, я трохи більше вичавив його, я думаю, що мені доведеться змінити алгоритм, щоб далі його зменшити
Джонатан Ландрум

1

Haskell, 102 байти

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

Те, що я спробував, було не коротше:

  • Висловлення всього з точки зору буквених символів та succабо predдля збереження map toEnum.
  • Запис діапазону вниз, а не використання reverse.
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.