Сделайте программу Треугольности действительной

19

Треугольность - это новый esolang, разработанный г-ном Xcoder, где структура кода должна следовать очень специфической схеме:

  • Для этой nстроки кода в ней должны быть ровно 2n-1символы программы. Это приводит к форме треугольника / пирамиды, причем первая строка имеет только один символ, а остальные увеличиваются с шагом 2.
  • Каждая строка должна быть дополнена .s слева и справа так, чтобы символы центрировались на их линиях, а все строки - одинаковой длины. Если lопределяется как количество строк в программе, каждая строка в программе должна иметь длину2 * l - 1

Например, программа слева действительна, но программа справа не является:

 Valid    |  Invalid  
          |
...A...   |  ABCDE
..BCD..   |  FGH
.EFGHI.   |  IJKLMN
JKLMNOP   |  OPQRS

Когда выложены в действующей структуре, имя становится очевидным.

задача

Ваша задача - взять в качестве входных данных однострочную строку, представляющую код треугольности, и вывести ее, преобразованную в действительный код, как описано выше.

Спецификации для ввода / вывода:

  • Ввод будет содержать только символы в диапазоне 0x20 - 0x7e
  • Длина ввода всегда будет квадратным числом и, таким образом, будет дополняться.
  • Вы должны использовать точки для заполнения вывода, а не что-то еще.

Вы можете вводить и выводить любым приемлемым способом. Это поэтому выигрывает самый короткий код в байтах !

Контрольные примеры

input
----
output

g
----
g

PcSa
----
.P.
cSa

DfJ0vCq7G
----
..D..
.fJ0.
vCq7G

7xsB8a1Oqw5fhHX0
----
...7...
..xsB..
.8a1Oq.
w5fhHX0

QNYATbkX2sKZ6IuOmofwhgaef
----
....Q....
...NYA...
..TbkX2..
.sKZ6IuO.
mofwhgaef

ABCDEF"$%& G8"F@
----
...A...
..BCD..
.EF"$%.
& G8"F@

ab.c
----
.a.
b.c

Для тех, кто знает треугольность, вы заметите из последнего теста, что строки не должны быть обработаны

Caird Coneheringaahing
источник
Песочница пост
caird coinheringaahing
13
Я понимаю, что это, вероятно, бесполезно, но неужели даунвотер захочет объяснить свой голос? Я хотел бы улучшить вызов в любом случае, я могу.
Caird Coneheringaahing
Допустимы ли начальные или конечные переводы строк?
Арно
@Arnauld Да, ведущие и конечные пробелы в порядке.
Caird Coneheringaahing
Список строк в порядке?
г-н Xcoder

Ответы:

19

Треугольность , 127 байтов

.......).......
......2)1......
...../)IL^.....
....f)rMD@_....
...)2)1/)IL^...
..f+`"'.'*"+E..
.DWReD)2s^)Its.
D+@sh+s+})10cJ.

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

объяснение

Удаляя символы, которые восполняют отступы, мы получаем следующую программу:

)2)1/)IL^f)rMD@_)2)1/)IL^f+`"'.'*"+EDWReD)2s^)ItsD+@sh+s+})10cJ

... Что довольно длинно, верно? Давайте разбить его на куски.

Генерация целых чисел [0… √len (вход))

)2)1/)IL^f)r – Subprogram #1.
)            – Creates a new stack entry, equal to 0. This must precede any integer
               literal, because each character in '0123456789' isn't parsed on its
               own as a literal, but rather they are commands which multiply the ToS
               by 10 and add the value of their digit equivalent. 
 2           – ToS * 10 + 2 = 2.           || STACK: [2]
  )1         – The literal 1.              || STACK: [2, 1]
    /        – Division.                   || STACK: [1 / 2] = [0.5]
     )I      – Get the input at index 0.   || STACK: [0.5, input]
       L     – Length.                     || STACK: [0.5, len(input)]
        ^    – Exponentiation.             || STACK: [len(input) ** 0.5]
         f   – Trim decimals.              || STACK: [int(len(input) ** 0.5)] 
          )r – Create the list [0 .. ToS). || STACK: [[0 ... int(len(input) ** 0.5))]

Генерация точек

MD@_)2)1/)IL^f+`"'.'*"+E – Subprogram #2.
MD                       – For each integer in the range, run some code on a separate
                           stack, preinitialised to two copies of the argument.
  @_                     – Increment and negate the ToS.
    )2)1/)IL^f           – The square root of the length of the input, again.
              +          – Add the two.
               `         – And cast the integer given to a string.
                "'.'*"+  – Prepends the literal "'.'*" to the string representation.
                       E – Evaluate as a Python expression (basically string repetition).

Обрезка персонажей спереди

DWReD)2s^)It – Subprogram #3.
D            – Duplicate the result of the expression above.
 W           – Wrap the whole intermediate stack to an array.
  Re         – Reverse the stack and dump the contents separately onto the stack.
    D        – Duplicate the result.
     )2      – Push the literal 2.
       s^    – Swap and perform exponentiation.
         )It – Push the input and trim the characters before that index.

Обрезка персонажей в конце

sD+@sh+s+ – Subprogram #4.
s         – Swap the top two elements on the stack.
 D+       – Double. Push twice and add.
   @      – Increment.
    sh    – Swap the top two elements and trim the characters after that index.
      +   – Append the first set of dots.
       s+ – And prepend the second set of dots.

Завершение цикла и красивая печать

})10cJ – Subprogram #5.
}      – End the loop.
 )10   – Push the literal 10.
    c  – Convert from code-point to character (yields '\n').
     J – And join the result by newlines.
Мистер Xcoder
источник
Вы должны забить байты для "." символы, если они предписаны внутренними особенностями языка?
JDL
@JDL Да, программа не может корректно работать без них, поэтому я должен включить их в число байтов :-)
Mr. Xcoder
Вам нужно «обрезать десятичные дроби», поскольку длина входных данных гарантированно будет квадратной? Вы также должны быть в состоянии получить стержень Jв конце и вывести массив строк. Не знаю, спасет ли это что-нибудь, хотя, если конец последней строки должен быть дополнен, .чтобы заполнить оставшееся пространство.
Лохматый
1
@ Shaggy 1) Да, fнеобходимо, потому что range не может принимать аргументы с плавающей запятой (даже с .0) 2) Избавление от Jне сохраняет байтов из-за заполнения, поэтому я выбрал более хороший формат вывода.
г-н Xcoder
8

Japt , 15 14 10 байт

Выводит массив строк.

ò@°T¬v1Ãû.

Попробуй это | Проверьте все тесты


Explantion

ò@     Ã       :Partition at characters where the following function returns true
  °T           :  Increment T (initially 0)
    ¬          :  Square root
     v1        :  Divisible by 1?
               :(Or, in other words, split after every character with a 1-based index that's a perfect square)
        û.     :Centre pad each element with .s to the length of the longest element

Оригинальное решение

ʬÆsTT±X+°XÃû.

Попытайся

Ê                  :Length of input
 ¬                 :Square root
  Æ        à       :Range [0,ʬ) and pass each X through a function
   s               :  Slice input
    T              :    from index T, initially 0
     T±X+°X        :    to index T incremented by X plus X incremented
            û.     :Centre pad each element with .s to the length of the longest element
мохнатый
источник
7

Шелуха , 15 байт

Ṡzö`JR2tR'.ṡCİ1

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

объяснение

Ṡzö`JR2tR'.ṡCİ1  Implicit input, say s = "DfJ0vCq7G".
             İ1  List of odd positive integers: [1,3,5,7,..
            C    Cut s to those lengths: x = ["D","fJ0","vCq7G"]
           ṡ     Reversed indices of x: y = [3,2,1]
Ṡz               Zip x and y using this function:
                  Arguments are a string and a number, e.g. r = "fJ0" and n = 2.
        R'.       n copies of '.': ".."
       t          Drop first element: "."
     R2           Two copies of this: [".","."]
  ö`J             Join by r: ".fJ0."
                 Result is ["..D..",".fJ0.","vCq7G"]; implicitly print on separate lines.
Zgarb
источник
7

05AB1E , 20 19 18 байт

Сохраненный байт благодаря Волшебной Урне Осьминога

ā·<£õKRvy'.N×.ø}r»

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

объяснение

ā                    # push the list [1 ... len(input)]
 ·<                  # multiply each by 2 and decrement each, making a list of odd numbers
   £                 # split the input into chunks of these sizes
    õK               # remove empty strings
      R              # reverse list
       vy      }     # for each y in the list
             .ø      # surround it with
         '.N×        # "." (dot) repeated N times, where N is the current iteration index
                r    # reverse the stack
                 »   # join stack by newlines
Emigna
источник
ÅÉшансы могут помочь?
Волшебная Урна Осьминога
Что-то вроде g;ÅÉ£Rvy'.N×.ø}r»? Но не это, потому что это не правильно, лол.
Волшебная Урна Осьминога
@MagicOctopusUrn: ÅÉопределенно помогло бы, если бы мы могли узнать длину нижнего ряда в 2 байта. Хотя я не знаю, сможем ли мы. Может быть еще один способ включить это.
Emigna
@MagicOctopusUrn: у меня было то же самое решение ранее, но я использовал )Rвместо rкоторого не сохранял ни одного байта: /
Emigna
Я пытался найти способ «перевернуть петлю», чтобы просто печатать, как это происходит, хотя никаких идей по этому поводу не было.
Волшебная урна с осьминогом
5

Желе ,  22  19 байт

J²‘Ṭœṗ⁸Ṛz”.Zµṙ"JC$Ṛ

Монадическая ссылка, возвращающая список списков символов (строк)

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

Как?

J²‘Ṭœṗ⁸Ṛz”.Zµṙ"JC$Ṛ - Link: list of characters e.g. "DfJ0vCq7G"
J                   - range of length               [1,2,3,4,5,6,7,8,9]
 ²                  - square (vectorises)           [1,4,9,16,25,36,49,64,81]
  ‘                 - increment                     [2,5,10,17,26,37,50,65,82]
   Ṭ                - untruth (1s at those indices) [0,1,0,0,1,0,0,0,0,1,0,0,0,0,0,0,1,...]
      ⁸             - chain's left argument         "DfJ0vCq7G"
    œṗ              - partition at indexes          ["D","fJ0","vCq7G"]
       Ṛ            - reverse                       ["vCq7G","fJ0","D"]
         ”.         - literal '.'                   '.'
        z           - transpose with filler         ["vfD","CJ.","q0.","7..","G.."]
           Z        - transpose                     ["vCq7G","fJ0..","D...."]
            µ       - start a new monadic chain
                 $  - last two links as a monad:
               J    -   range of length             [1,2,3]
                C   -   complement (vectorises)     [0,-1,-2]
              "     - zip with:
             ṙ      -   rotate left by              ["vCq7G",".fJ0.","..D.."]
                  Ṛ - reverse                       ["..D..",".fJ0.","vCq7G"]
Джонатан Аллан
источник
5

JavaScript (ES7), 82 78 байт

f=(s,k=1-s.length**.5*2,p='')=>s&&f(s.slice(0,k),k+2,p+'.')+`
`+p+s.slice(k)+p

Контрольные примеры

комментарии

f = (                       // f = recursive function taking:
  s,                        //   s = input string
  k = 1 - s.length**.5 * 2, //   k = additive inverse of the length of the base
  p = ''                    //   p = padding string
) =>                        //
  s &&                      // if s is not empty:
    f(                      //   do a recursive call with:
      s.slice(0, k),        //     s without the last -k characters
      k + 2,                //     the updated base length (2 less characters)
      p + '.'               //     the updated padding string
    ) +                     //   end of recursive call()
    `\n` +                  //   append a line feed
    p +                     //   append the left padding string
    s.slice(k) +            //   append the last -k characters of s
    p                       //   append the right padding string
Arnauld
источник
[несовершеннолетний] символ '/ n' стал фактическим разрывом строки в блоке кода вверху - подумайте, чтобы избежать его для ясности :)
G0BLiN
@ G0BLiN Это наоборот: это является действительно буквальным разрыв строки в golfed кода, который был заменен на сбежавший разрыве строки в ungolfed версии для ясности. :)
Арно
Ха, шутка на меня, тогда ... :-)
G0BLiN
2

MATL , 21 байт

tnX^eRP&1ZvGyg(46y~(!

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

объяснение

Рассмотрим ввод 'DfJ0vCq7G'в качестве примера. Содержимое стека показывается через запятую, а верхний элемент последний. Строки в массиве 2D используют точку с запятой в качестве разделителя.

t      % Implicit input: string. Duplicate
       % STACK: 'DfJ0vCq7G',
                'DfJ0vCq7G'
nX^    % Number of elements. Square root
       % STACK: 'DfJ0vCq7G',
                3
e      % Reshape with that many rows (in column major order)
       % STACK: ['D0q';
                 'fv7';
                 'JCG']
R      % Upper triangular part: set elements below diagonal to char(0)
       % (displayed as space)
       % STACK: ['D0q';
                 ' v7';
                 '  G']
P      % Flip vertically
       % STACK: ['  G';
                 ' v7';
                 'D0q']
&1Zv   % Reflect vertically
       % STACK: ['  G';
                 ' v7';
                 'D0q';
                 ' v7';
                 '  G']
G      % Push input again
       % STACK: ['  G';
                 ' v7';
                 'D0q';
                 ' v7';
                 '  G'],
                'DfJ0vCq7G'
yg     % Duplicate from below and convert to logical. This gives true for
       % for nonzero chars (the entries where input chars will be written)
       % STACK: ['  G';
                 ' v7';
                 'D0q';
                 ' v7';
                 '  G'],
                'DfJ0vCq7G',
                [0 0 1;
                 0 1 1;
                 1 1 1;
                 0 1 1;
                 0 0 1]
(      % Assignment indexing: write values at those positions
       % STACK: ['  v';
                 ' fC';
                 'DJq';
                 ' 07';
                 '  G']
46     % Push 46, which is ASCII for '.'
       % STACK: ['  v';
                 ' fC';
                 'DJq';
                 ' 07';
                 '  G'],
                 46
y~     % Duplicate from below and apply logical negate. This gives true
       % for char(0) (the entries where '.' will be written)
       % STACK: ['  G';
                 ' v7';
                 'D0q';
                 ' v7';
                 '  G'],
                46
                [1 1 0;
                 1 0 0;
                 0 0 0;
                 1 0 0;
                 1 1 0]
(      % Assignment indexing: write value at those positions
       % STACK: ['..G';
                 '.v7';
                 'D0q';
                 '.v7';
                 '..G'],
!      % Transpose. Implicit display
       % STACK: ['..D..';
                 '.fJ0.';
                 'vCq7G']
Луис Мендо
источник
1

Perl, 56 52 байта

Включает +3в себя для-p

#!/usr/bin/perl -p
$_=("."x y///c**.5)=~s%.%$'@{[$&x/$`$`./g]}$'
%rg

Предоставить ввод для STDIN (в принципе без окончательного перевода строки, но это имеет значение только для пустого ввода)

Тон Хоспел
источник
1
по правилам PCG -pстоит всего 1 байт
mik
@mik Только если код не содержит '. Но этот код делает, поэтому его нужно поместить в файл (или экранировать в командной строке), который требует 3 дополнительных символа по сравнению с обычной #!строкой. Так что в этом случае это так +3(для нормального кода вы увидите, что я действительно рассчитываю только +на это p)
Тон Хоспел
1

Красный , 227 203 байта

f: func[s][l: to-integer(length? s)** 0.5
n: 0 foreach m parse s[collect[(r: []repeat i l[append r reduce['keep i * 2 - 1
charset[not{Я}]]])r]][v: copy""insert/dup v"."l - n: n + 1 print rejoin[v m v]]]

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

Ungolfed:

f: func[s][
l: to-integer (length? s) ** 0.5
n: 0
foreach m parse s [ 
    collect [
        (r: []
        repeat i l [ append r reduce [
            'keep i * 2 - 1 charset [ not{Я} ]]])
    r ]] 
    [v: copy ""
    insert/dup v "." l - n: n + 1
    print rejoin [v m v]]
]
Гален Иванов
источник
1

Retina , 88 72 71 байт

S1`
+m`^(.)+¶(?>(?<-1>.)+)..(?!¶)
$&¶
P^'.m`^.(?=(..)*)(?<-1>.)*
P'.`.+

Попробуйте онлайн! Изменить: Сохранено 12 13 байт благодаря @MartinEnder. Объяснение:

S1`

Разделите первого персонажа на собственную линию, чтобы заставить мяч катиться.

+m`^(.)+¶(?>(?<-1>.)+)..(?!¶)
$&¶

Разрежьте каждую строку на два символа длиннее предыдущего.

P^'.m`^.(?=(..)*)(?<-1>.)*

Левая клавиша первой половины каждой строки, эффективно их центрируя.

P'.`.+

Правый блокнот всех линий.

Нил
источник
1

Древесный уголь , 21 19 байт

UB.F₂Lθ«P✂θXι²X⊕ι²↙

Попробуйте онлайн! Ссылка на подробную версию кода. Редактировать: Сохранено 2 байта путем обнаружения SquareRoot. Объяснение:

UB.                 Set the background fill to `.`
      θ             (First) input
     L              Length
    ₂               Square root
   F   «            Loop over implicit range
            ι   ι   Current value
               ⊕    Incremented
             ²   ²  Literal 2
           X  X     Power
         ✂θ         Slice the (first) input string
        P           Print without moving the cursor
                  ↙ Move down left
Нил
источник
: / Это почти работает, но кажется, что уголь немного глючит. Это работает, хотя, я думаю?
Только для ASCII
@ Только для ASCII ... что это за чёрная магия?
Нил
Fill в основном проверяет наличие нулевых байтов (т. Е. Символа, используемого для пробела, где ничего не рисуется), поэтому вы можете просто нарисовать многоугольник с нулевыми байтами (ну, если он даже работает правильно> _>) и заполнить его. Очевидно, что это не совсем так, потому что по какой-то причине вы можете видеть нулевые байты даже до заполнения> _>
только для ASCII
это должно работать должным образом, следующее нажатие
только ASCII
0

Рубин , 73 66 байт

->s{(1..z=s.size**0.5).map{|q|s[q*q-2*q+1...q*q].center 2*z-1,?.}}

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

-5 байт: вернуть массив строк вместо их печати

-2 байта: объявить zна месте, а не раньше времени

Ungolfed:

->s{
  (1..z=s.size**0.5).map{|q|   # Map the range [1,sqrt(s.size)]
    s[q*q-2*q+1...q*q]         # To the relevant portion of s,
      .center 2*z-1, ?.        #   padded left and right with . characters
  }
}

Объявление переменной, r=q-1чтобы я мог взять, s[r*r...q*q]сохраняет ровно ноль байтов.

Использование .centerвместо заполнения вручную также экономит ноль байтов, но мне это нравится больше.

benj2240
источник