Вы должны построить 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
HyperNeutrino,

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

4
Есть ли причина, по которой это не называется «Вы должны построить пилоны ASCII!»?
Матдм

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

@Riking Для этого вам понадобится особый случай, как создается массив символов, чтобы создать только один элемент вместо 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 Тьфу, классическая ошибка off-by-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 представил решение 71 байт, которое улучшилось до 70 байт . Они избегают иметь дело с 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

3

Рубин , 70 байт

s=[*?\s..?~]*'';48.times{|i|puts s[i,i+1].rjust(48)+s.reverse[-2*i,i]}

Попробуйте онлайн!

Создает полную печатаемую строку ASCII, а затем печатает необходимое количество прямых (дополненных пробелами) + обратных кусочков.



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

Попробуйте онлайн!

Ungolfed:

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 новых символа в центр строки, затем обрезаю дополнительные элементы с обоих концов, используя функцию SQLSTUFF() .

Отформатирован и объяснен:

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

Попробуйте онлайн!

Спасибо Конору О'Брайену за шаблон! Спасибо FrownyFrog за указание неверного решения.


1
Возможно, это легче изменить: попробуйте онлайн!
Конор О'Брайен

@ Конор О'Брайен - Спасибо за шаблон, я обновил ссылку.
Гален Иванов

Печатает дополнительную строку вверху.
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спасибо Galen Ivanov и Conor O'Brien за идеи в их решениях

37 включенных эхо echo u:32+|.(~.(>:*+:@[-])"0 _])|i:47

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

Включая советы @FrownyFrog из комментариев

TIO


Я не думаю, что выражения являются действительными представлениями.
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
Мертвый Поссум

1

Рубин , 78 байт

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

Попробуйте онлайн!

Полная программа. Ungolfed:

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

MY-BASIC , 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

Gol> <> , 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.