Давайте создадим цифровую мозаику

25

Вызов

Учитывая положительное целое число , повторить каждый из его цифр количество раз , соответствующее его положению в . Другими словами, каждая цифра должна повторяться раз (для каждого , 1-проиндексированного), создавая тем самым новый номер:1 k nN N d k kd1,d2,d3,,dnNdkk1kn

d1d2d2d3d3d3dndndndnn times¯

Затем запишите его как по горизонтали, так и по вертикали и заполните поля копиями цифры, которая соответствует большему индексу между индексом столбца и индексом строки пробела. Окончательный результат должен выглядеть следующим образом:

[d1d2d2d3d3d3d2d2d2d3d3d3d2d2d2d3d3d3d3d3d3d3d3d3d3d3d3d3d3d3d3d3d3d3d3d3]

Спекуляции

Вы можете принять как целое число, строку, список цифр или список символов, представляющих цифры. Выводом может быть строка, разделенная новой строкой, список строк / целых чисел или список списков символов / цифр, но, если это возможно, включите также версию для симпатичной печати. Если вывод представляет собой строку, разделенную символом новой строки, также допустимо:N

  • иметь начальные / конечные пробелы, если внешний вид вывода не изменяется
  • разделите столбцы, используя одинаковое количество пробелов или строки с постоянным (ненулевым) количеством новых строк

Вы можете получить ввод и предоставить вывод любым стандартным методом , при этом отметив, что эти лазейки по умолчанию запрещены. Это , поэтому постарайтесь выполнить задачу за наименьшее количество байтов, которыми вы можете управлять на выбранном вами языке .

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

65:

655
555
555

---------------

203:

200333
000333
000333
333333
333333
333333

--------------

233:

233333
333333
333333
333333
333333
333333

---------------

5202:

5220002222
2220002222
2220002222
0000002222
0000002222
0000002222
2222222222
2222222222
2222222222
2222222222

---------------

12345:

122333444455555
222333444455555
222333444455555
333333444455555
333333444455555
333333444455555
444444444455555
444444444455555
444444444455555
444444444455555
555555555555555
555555555555555
555555555555555
555555555555555
555555555555555
Мистер Xcoder
источник
Есть ли у нас дескрипторы двух одинаковых цифр рядом друг с другом?
Дом Гастингс
@DomHastings Да, вы должны справиться с ними. Добавлен тестовый пример, иллюстрирующий это.
Мистер Кскодер
Связанный
Магическая урна с осьминогом

Ответы:

9

JavaScript (ES7), 70 байт

Принимает ввод в виде строки. Возвращает строку с завершающим переводом строки.

s=>(g=x=>(c=s[(x>y?x:y)**.5-1>>1])?c+g(x+8):x>y?`
`+g(1,y+=8):'')(y=1)

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

Как?

метод

Мы строим вывод за символом, проходя квадратную матрицу и преобразовывая каждую ячейку в индекс во входную строку.ix,y

Координаты к строковому индексу

Верхняя граница области чисел (с индексами 0) вдоль каждой оси задается A000096 : п т чunnth

u0=0,u1=2,u2=5,u3=9,u4=14,u5=20,

un=n(n+3)2
u0=0,u1=2,u2=5,u3=9,u4=14,u5=20,

Учитывая целое число , мы можем узнать, в какой области оно находится, решив:n = x+ 1kn=x+1

x²+3x2k=0

Ведущий к:

n=

x=1+8k32
n=1+8k32+1=1+8k12

Для каждой ячейки мы определяем:(x,y)

vx,y=max(1+8x,1+8y)

Эти значения преобразуются в индексы во входную строку следующим образом: i x , yvx,yix,y

ix,y=vx,y12
 v(x,y) |  0  1  2  3  4  5  6  7  8  9        i(x,y) |  0  1  2  3  4  5  6  7  8  9
--------+-------------------------------      --------+-------------------------------
    0   |  1  9 17 25 33 41 49 57 65 73           0   |  0  1  1  2  2  2  3  3  3  3
    1   |  9  9 17 25 33 41 49 57 65 73           1   |  1  1  1  2  2  2  3  3  3  3
    2   | 17 17 17 25 33 41 49 57 65 73           2   |  1  1  1  2  2  2  3  3  3  3
    3   | 25 25 25 25 33 41 49 57 65 73           3   |  2  2  2  2  2  2  3  3  3  3
    4   | 33 33 33 33 33 41 49 57 65 73   -->     4   |  2  2  2  2  2  2  3  3  3  3
    5   | 41 41 41 41 41 41 49 57 65 73           5   |  2  2  2  2  2  2  3  3  3  3
    6   | 49 49 49 49 49 49 49 57 65 73           6   |  3  3  3  3  3  3  3  3  3  3
    7   | 57 57 57 57 57 57 57 57 65 73           7   |  3  3  3  3  3  3  3  3  3  3
    8   | 65 65 65 65 65 65 65 65 65 73           8   |  3  3  3  3  3  3  3  3  3  3
    9   | 73 73 73 73 73 73 73 73 73 73           9   |  3  3  3  3  3  3  3  3  3  3

Условия остановки

Мы знаем, что мы достигли:

  • правая граница матрицы, когда символ в не существует, и мы имеем х > уix,yx>y

  • нижняя граница матрицы, когда символ не существует, и мы имеемxy

Arnauld
источник
7

J , 16 15 байт

-1 байт благодаря FrownyFrog!

{~#\<:@>./~@##\

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

Принимает Nкак строку.

Пояснения к исходному решению:

              #\   finds the length of the successive prefixes of the input (1 2 3...)
            #~     copies each digit as many times (1 2 2 3 3 3...)  
       >./~@       and creates a table of the max of the row/col numbers
  [:<:@            then subtract 1 from each element (for indexing)
{~                 select the corresponding digit from the input

Тестовая сессия с вводом 203:

   #\ '203'
1 2 3

   #~#\ '203'
1 2 2 3 3 3

   >./~@#~#\ '203'
1 2 2 3 3 3
2 2 2 3 3 3
2 2 2 3 3 3
3 3 3 3 3 3
3 3 3 3 3 3
3 3 3 3 3 3

   <:@>./~@#~#\ '203'
0 1 1 2 2 2
1 1 1 2 2 2
1 1 1 2 2 2
2 2 2 2 2 2
2 2 2 2 2 2
2 2 2 2 2 2

   ({~[:<:@>./~@#~#\) '203'
200333
000333
000333
333333
333333
333333
Гален Иванов
источник
1
Ха, кроме размещения ), ваш ответ APL такой же, как и у меня.
Эрик Outgolfer
Я действительно совсем не знаю J, но мне [:<:@кажется, что это довольно дорого. Не могли бы вы вместо этого добавить что-то к списку, в который вы индексируете, для учета индексации 1 (например, добавьте 0, чтобы переместить каждый необходимый элемент 1 на одну позицию вправо)?
г-н Xcoder
@ Mr.Xcoder Я думал об этом. Я попробую это, чтобы видеть, спасло ли бы это некоторые байты.
Гален Иванов
@EriktheOutgolfer {⍵[∘.⌈⍨(/⍨)⍳⍴⍵]} ?
Гален Иванов
@GalenIvanov Да, это.
Эрик Outgolfer
6

Python 2 , 71 байт

i=j=0;r=''
for x in input():i+=1;r+=x*i
for c in r:print j*c+r[j:];j+=1

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

Сначала генерируется первая строка r, затем выполняется итерация rдля печати каждой строки.

XNOR
источник
6

R , 59 байт

function(a){m=outer(x<-rep(g<-seq(a),g),x,pmax);m[]=a[m];m}

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

  • Я заметил, что взятие вектора цифр допустимо, и это позволило мне сэкономить 21 байт :)
  • -2 байта благодаря предложению @Giuseppe принимать только символьный вектор
  • -2 байта в определении аргументов
digEmAll
источник
1
Вы можете взять aв качестве вектора символов, что позволяет вам установить g=seq(a)непосредственно.
Джузеппе
@ Джузеппе: это верно!
digEmAll
5

05AB1E , 14 11 10 байт

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

ƶJDv¬N×?=¦

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

объяснение

ƶ            # repeat each element its index (1-based) times 
 J           # join to string
  Dv         # for N in [0 ... len(string)-1] do
    ¬N×      # push the head repeated N times
       ?     # print without newline
        =    # print the rest of the string without popping
         ¦   # remove the head
Emigna
источник
1
Попробуйте онлайн! = 10
Волшебная урна осьминога
1
Но мне не в чести, но это заслуга Аднана: codegolf.stackexchange.com/a/87074/59376
Урна магического осьминога
@MagicOctopusUrn: Ах, это замечательно! Спасибо вам обоим;)
Эминья
3

Excel VBA, 95 байт

Функция анонимного непосредственного окна VBE, которая принимает входные данные [A1]и выводит их на консоль

n=[len(A1)]:For y=1To n:For l=1To y:?:For x=1To n:?String(x,Mid([A1],IIf(x>y,x,y)));:Next x,l,y

Разоблаченный и прокомментированный

n=[len(A1)]                         ''  Get Length
For y=1To n                         ''  Iterate down input
For l=1To y                         ''  Iterate down repeat lines
?                                   ''  Print Newline
For x=1To n                         ''  Iterate accross input
?String(x,Mid([A1],IIf(x>y,x,y)));  ''  Print x of the `max(x,y)`th digit in input
Next x,r,y                          ''  Loop, Loop, Loop
Тейлор Скотт
источник
2

MATL , 15 12 байт

tftY"t!2$X>)

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

Я подозреваю, что это можно сократить, но это не так уж плохо ...

          % implicit input, '230'
t         % duplicate input. Stack: ['230','230']
f         % indices of nonzero values. Stack: ['230',[1,2,3]]
t         % duplicate. Stack: ['230',[1,2,3],[1,2,3]]
Y"        % run-length decoding. Stack: ['230',[1,2,2,3,3,3]]
t         % duplicate. Stack: ['230',[1,2,2,3,3,3],[1,2,2,3,3,3]]
!         % transpose. Stack: ['230',[1,2,2,3,3,3],[1;2;2;3;3;3]]
2$X>      % elementwise maximum of 2 inputs, with broadcast.
          % Stack:
          % ['230',
          % [1, 2, 2, 3, 3, 3;
          %  2, 2, 2, 3, 3, 3;
          %  2, 2, 2, 3, 3, 3;
          %  3, 3, 3, 3, 3, 3;
          %  3, 3, 3, 3, 3, 3;
          %  3, 3, 3, 3, 3, 3]]
 )        % index into G
          % implicit end, display stack contents
Giuseppe
источник
2

Добавить ++ , 35 байт

L,bLRdBcB]£X¦Ω+d‽b>1€Ω_A€Ω:AbLR¦+$T

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

Как это работает

Мы принимаем входные данные как список цифр, в то же время не позволяя нам а) приводить к цифрам BD, а также сохранять цифры, что заняло бы два байта.

bLRnndBcB][[1,1],[2,2]...[n,n]]£X¦Ω+

Далее мы продублируем этот массив и добавим в таблицу максимум d‽b>. Т.е. каждый элемент в массиве сопряжен с каждым другим элементом из второго массива, и по паре запускается команда максимального двоичного числа. Для примера ввода [6 5] это создает массив [1 2 2 2 2 2 2 2 2] , который является уплощенной версией мозаики, в качестве индексов для массива. К сожалению, добавить ++ использует 0-индексированные массивы, так что мы должны уменьшаем каждый элемент: 1€Ω_.

A€Ω:x

x(x1)2

xth AbLR¦+Tn$T


источник
1

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

F⮌…LθUO⊕⊘×ι⁺³ι§θι

Попробуйте онлайн! Объяснение:

F⮌…Lθ

Цикл по индексам символов в обратном порядке.

⊕⊘×ι⁺³ι

Рассчитайте размер квадрата.

UO...§θι

Нарисуйте квадрат, используя текущий персонаж.

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

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

E⭆θ×⊕κι×⊕κι‖O↗

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

Как?

E⭆θ×⊕κι×⊕κι‖O↗ - implicitly print the result of...
E                - map:
  ⭆              -   over: string map:       
    θ             -     over: first input
     ×            -     using: repeat
        ι         -       what: ι (loop value)
      ⊕κ          -       by: incremented κ (loop counter)
         ×        -   using: repeat
            ι     -     what: ι (loop value)
          ⊕κ      -     by: incremented κ (loop counter)
             ‖O  - Reflect with overlap:
                ↗ -   direction: up-right

... можно ли использовать этот метод в гольфе?

Джонатан Аллан
источник
"... можно ли использовать этот метод в гольфе?" Даже решение Нейла длиннее, поэтому я не вижу здесь никакой надежды. : P
Эрик Outgolfer
×⊕κιхотя дважды.
Джонатан Аллан
Дело в том, что присвоить это переменной непросто, поскольку значения ιи κменяются на каждой итерации цикла Each.
Эрик Outgolfer
Это должна быть функция, но я не знаю, возможно ли это вообще.
Джонатан Аллан
Вопрос, который нужно задать, состоит в том, возможно ли это в 3 (или 5, в зависимости от того, как определяется функция) байтов или меньше. ;) (Очевидный ответ, конечно же, нет.)
Эрик Outgolfer
1

Stax , 12 байт

ü°√¿«│⌠º₧@\τ

Запустите и отладьте его

Используя этот алгоритм .

Объяснение:

c%R:BXm]i*xit+ Full program, implicit input
c%             Length of input
  R            1-based range
   :B          Repeat each element according to the range ("123" -> "122333")
     X         Save to X register
      m        Map:
       ]         Character -> string
        i*       Repeat by iteration index
          xit    Trim first <iteration index> elements from X
             +   Concatenate
                 Implicit output with newline

Stax , 20 19 18 16 байт

ù↔‼i,ÑΓæ☺=╘‼æ↕4╝

Запустите и отладьте его

Объяснение:

c%R:BX%mYx%{y|Mvx@m Full program, implicit input
c%                  Length of input
  R                 1-based range
   :B               Repeat each element according to the range ("123" -> "122333")
     X              Save to X register
      %             Length
       m            Map over 1-based range:
        Y             Save index to Y register
         x%           Push length of X register
           {      m   Map over 1-based range:
            y|M         Maximum of both indices
               v        1-based -> 0-based (decrement)
                x@      Index into X register
                      Implicit output with newline
Wastl
источник
1

Атташе , 34 байта

{_[Table[Max,Flat!{_&_}=>1:#_]-1]}

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

объяснение

Работает аналогично ответу Галена Иванова .

{_[Table[Max,Flat!{_&_}=>1:#_]-1]}
{                                }   anonymous function: _ is input, array of digits
                                     example: _ := [2, 0, 3]
                         1:#_        the range 1 to Size[_]
                                     > e.g.: [1, 2, 3]
                  {   }=>            over each number N:
                   _&_                   map to N repeated N times
                                     > e.g.: [[1], [2, 2], [3, 3, 3]]
             Flat!                   flatten it
                                     > e.g.: [1, 2, 2, 3, 3, 3]
   Table[Max,                ]       create a "max" table with it
                                     > e.g.:
                                       1 2 2 3 3 3
                                       2 2 2 3 3 3
                                       2 2 2 3 3 3
                                       3 3 3 3 3 3
                                       3 3 3 3 3 3
                                       3 3 3 3 3 3
                              -1     subtract 1 from each
                                     > e.g.:
                                       0 1 1 2 2 2
                                       1 1 1 2 2 2
                                       1 1 1 2 2 2
                                       2 2 2 2 2 2
                                       2 2 2 2 2 2
                                       2 2 2 2 2 2
 _[                             ]    index the original array with this matrix
                                     > e.g.:
                                       2 0 0 3 3 3
                                       0 0 0 3 3 3
                                       0 0 0 3 3 3
                                       3 3 3 3 3 3
                                       3 3 3 3 3 3
                                       3 3 3 3 3 3
Конор О'Брайен
источник
1

C (gcc) , 130 байтов

Кому нужна модная математика, когда ты можешь перебор?

n,l;R(n,c){for(;n--;)putchar(c);}f(s){for(char*p=s,*q;*p++;)for(n=l=p-s;l--;R(1,10))for(R(n*n+n>>1,p[-1]),q=p;*q;q++)R(q-s+1,*q);}

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

gastropner
источник
1

QBasic 1.1 , 127 байт

INPUT S$
FOR X=1TO LEN(S$)
K=K+X
R$=R$+STRING$(X,MID$(S$,X,1))
NEXT
FOR C=1TO K
?STRING$(C-1,MID$(R$,C,1))RIGHT$(R$,K-C+1)
NEXT

-4 благодаря DLosc .

Использует модифицированную версию алгоритма xnor Python 2 .

Ввод - это строка без кавычек. Выход- \nотделяется без лишних пробелов или \ns.

Эрик Outgolfer
источник
1

QBasic , 111 байт

Анонимная функция, которая запрашивает ввод и вывод на консоль.

INPUT s$
n=LEN(s$)
FOR y=1TO n
FOR l=1TO y
?
FOR x=1TO n
z=x
IF y>x THEN z=y
?STRING$(x,MID$(s$,z));
NEXT x,l,y
Тейлор Скотт
источник
Выглядит хорошо - но разве вы не имеете в виду «полную программу»? Я не думаю, что QBasic имеет «анонимные функции».
DLosc
0

Php 7.1 , 163 байта

Через CLI, предоставив номер в качестве аргумента:

<?foreach(str_split($argv[1])as$k=>$d)$a[]=array_fill(0,$s+=$k+1,array_fill(0,$s,$d));foreach(array_replace_recursive(...array_reverse($a))as$v)echo join($v)."\n";

Не так уж и гольф

$n = 123;

foreach(str_split($n) as $k => $d) {
    $s += $k + 1;
    $a[] = array_fill(0, $s, array_fill(0, $s, $d));
}

foreach(array_replace_recursive(...array_reverse($a)) as $v)
    echo implode('', $v) . "\n";

Выход:

122333
222333
222333
333333
333333
333333

Метод:

В основном строят квадраты многомерного массива, состоящие из цифры, а затем накладывают их все (array_replace_recursive).

(Да, я знаю, что это очень долго.)

Progrock
источник
Если входные данные представляют собой предварительно определенный массив цифр, а вывод / объединение эха удаляется / заменяется назначением в список списка цифр, это может быть уменьшено примерно до 119 байтов, да, все еще долго.
Progrock
0

Japt, 12 байт

Принимает ввод в виде строки, выводит массив строк.

Ë+pE
¬£h°YçX

Попытайся


объяснение

            :Implicit input of string U
Ë           :Map each character D at 0-based index E
  pE        :  Repeat D E times
 +          :  Append to D
\n          :Reassign to U
¬           :Split to character array
 £          :Map each element X at 0-based index Y
   °Y       :  Increment Y
     çX     :  Repeat X Y times
  h         :  Replace the first Y characters in U with that
мохнатый
источник
0

uBASIC , 120 байтов

Анонимная функция, которая принимает входной поток STDIN и выводит в STDOUT

0Input"",S$:N=Len(S$):ForY=1ToN:ForL=1ToY:ForX=1ToN:ForC=1ToX:Z=X:IfY>XThenZ=Y
1?Mid$(s$,z,1);:NextC:NextX:?:NextL:NextY

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

Тейлор Скотт
источник
0

Visual Basic .NET (VBC) , 198 байт

SubПроцедура , которая принимает входные данные из STDIN и выводит в STDOUT.

Не могу заставить StrDup работать: /

Module M
Sub Main
Dim c,s,n,l,x,y
s=Console.readLine()
n=Len(s)
For y=1To n
For l=1To y
For x=1To n
For c=1To x
Console.Write(Mid(s,IIf(x>y,x,y),1)&IIf(c=n,vbLf,""))
Next c,x,l,y 
End Sub
End Module

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

Тейлор Скотт
источник
0

Луа, 149 140 байт

Функция, которая принимает список цепочек цифр и печатает результат в стандартный вывод. Это моя первая попытка кода в гольф (и выбор языка тоже не помогает), так что терпите меня :)

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

function(a)F,s=0,""for b=1,#a do s=s..a[b]:rep(b)end;for b=1,#a do io.write((s.."\n"):rep(b))F,z=F+b,a[b+1]or""s=z:rep(F)..s:sub(F+1)end end

Ungolfed:

G = function(p)
    F,s = 0,""
    for i=1,#p do
        s=s..p[i]:rep(i)
    end
    for i=1, #p do
        io.write((s.."\n"):rep(i))
        F,z = F+i, p[i+1]or""
        s = z:rep(F)..s:sub(F+1)
    end
end
-- allows to pass the argument list from stdin
-- example: {"1", "2", "3", "4", "5"}
G(load("return " .. io.read())())
PhilipRoman
источник
0

Ябасич , 108 байт

Анонимная функция, которая принимает входные данные из STDIN и выводит их в STDOUT

Input""s$
n=len(s$)
For y=1To n
For r=1To y
For x=1To n
For c=1To x?Mid$(s$,max(x,y),1);Next
Next
?Next
Next

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

Тейлор Скотт
источник