Вывод визуальной схемы картинки

22

Напишите программу, которая вводит размеры рисунка, ширину матирования и ширину рамки для портрета в рамке. Программа должна вывести диаграмму, используя символ Xдля рисования, +для матирования и #для обрамления. Символы должны быть разделены пробелом. Конечный пробел в порядке, если результат визуально соответствует критериям. Входы могут быть 0.

ВХОД: 3 2 1 2 (ширина, высота, матовая ширина, ширина кадра)

ВЫХОД:

Первые 3 и 2 - ширина и высота окраски.  1 - это матовая ширина вокруг него.  2 - ширина рамки вокруг всего.

В текстовой форме:

# # # # # # # # #
# # # # # # # # #
# # + + + + + # #
# # + X X X + # #
# # + X X X + # #
# # + + + + + # #
# # # # # # # # #
# # # # # # # # #

Код выигрыша завершает условия в наименьшем количестве байтов.

Джордж Харрис
источник
2
Отличный вызов! Для будущих испытаний вы можете использовать Песочницу
MilkyWay90
2
Вы не возражаете, если ввод в другом порядке?
Витявв
1
Можем ли мы вернуть список строк?
MilkyWay90
5
Может ли какой-либо из входов быть нулевым?
Лайкони
1
Можем ли мы иметь пробел в конце каждой строки?
Луис Мендо

Ответы:

5

Python 2 , 98 байт

w,h,a,b=input()
a*='+'
b*='#'
for c in b+a+h*'X'+a+b:print' '.join(min(c,d)for d in b+a+w*'X'+a+b)

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

Печатает разделенную пробелами сетку, строго следуя спецификации. Меня удивляет, что *=используется для преобразования aи bиз чисел в строки.

Python 3 может сохранить некоторые байты, избегая ' '.join, может быть, больше, используя f-строки и выражения присваивания. Спасибо Джо Кингу за -2 байта.

Python 3 , 93 байта

def f(w,h,a,b):a*='+';b*='#';[print(*[min(c,d)for d in b+a+w*'X'+a+b])for c in b+a+h*'X'+a+b]

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

XNOR
источник
Я был вне игры! Отличная работа, кажется, довольно гольф
MilkyWay90
Хороший гольф! Очень умно.
Джордж Харрис
4

JavaScript (ES6),  118 113  107 байт

(w,h,M,F)=>(g=(c,n)=>'01210'.replace(/./g,i=>c(i).repeat([F,M,n][i])))(y=>g(x=>'#+X'[x<y?x:y]+' ',w)+`
`,h)

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

комментарии

(w, h, M, F) => (       // given the 4 input variables
  g = (                 // g = helper function taking:
    c,                  //   c = callback function returning a string to repeat
    n                   //   n = number of times the painting part must be repeated
  ) =>                  //
    '01210'             // string describing the picture structure, with:
    .replace(           //   0 = frame, 1 = matte, 2 = painting
      /./g,             // for each character in the above string:
      i =>              //   i = identifier of the current area
        c(i)            //   invoke the callback function
        .repeat         //   and repeat the result ...
        ([F, M, n][i])  //   ... either F, M or n times
    )                   // end of replace()
)(                      // outer call to g:
  y =>                  //   callback function taking y:
    g(                  //     inner call to g:
      x =>              //       callback function taking x:
        '#+X'           //         figure out which character to use
        [x < y ? x : y] //         according to the current position
        + ' ',          //         append a space
      w                 //       repeat the painting part w times
    )                   //     end of inner call
    + '\n',             //     append a line feed
  h                     //   repeat the painting part h times
)                       // end of outer call
Arnauld
источник
3

MATL , 24 байта

&l,ithYaQ]'#+X'w)TFX*cYv

Входные данные: высота, ширина, матовая ширина, ширина кадра.

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

объяснение

&l      % Take height and width implicitly. Push matrix of that size with all
        % entries equal to 1
,       % Do twice
  i     %   Take input
  th    %   Duplicate, concatenate: gives a 1×2 vector with the number repeated
  Ya    %   Pad matrix with those many zeros vertically and horizontally
  Q     %   Add 1 to each entry 
]       % End
'#+X'   % Push this string
w)      % Index into the string with the padded matrix
TF      % Push row vector [1 0]
X*      % Kronecker product. This inserts columns of zeros
c       % Convert to char again. Char 0 is will be displayed as space
Yv      % Remove trailing spaces in each line. Implicitly display
Луис Мендо
источник
2

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

≔×NXθ≔×NXηFE+#×Nι«≔⁺ι⁺θιθ≔⁺ι⁺ηιη»Eη⪫⭆θ⌊⟦ιλ⟧ 

Попробуйте онлайн! Ссылка на подробную версию кода. Примечание: конечный пробел. Редактировать: теперь использует алгоритм @ xnor. Объяснение:

≔×NXθ≔×NXη

Введите ширину и высоту и конвертируйте их в строки Xs.

FE+#×Nι

Цикл по символам +и #, преобразовывая их в строки длины, заданной оставшимися двумя входами. Затем зациклите эти две строки.

«≔⁺ι⁺θιθ≔⁺ι⁺ηιη»

Префикс и суффикс картины со строками для матирования и обрамления.

Eη⪫⭆θ⌊⟦ιλ⟧ 

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

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

05AB1E (наследие) / 05AB1E --no-lazy , 32 31 байт

и'Xׄ+#vyI©×UεX.ø}®FDнgy×.ø]€S»

Принимает ввод в порядке height, width, matte, frame. Если порядок ввода, указанный в запросе, является строгим (все еще ожидающим проверки на OP), можно добавить начальный s(своп) для +1 байта.

Требуется --no-lazyфлаг компилятора Elixir в новой версии 05AB1E, поскольку Elixir ведет себя странным образом из-за ленивых вычислений для вложенных карт / циклов ( здесь результат без этого флага ).

Попробуйте онлайн в устаревшей версии 05AB1E.
Попробуйте онлайн в новой версии 05AB1E с добавленным --no-lazyфлагом.

Объяснение:

и              # Repeat the second (implicit) input the first (implicit) input amount of
               # times as list
 'X×          '# Repeat "X" that many times
„+#v           # Loop `y` over the characters ["+","#"]:
    y          #  Push character `y`
     I         #  Push the next input (matte in the first iteration; frame in the second)
      ©        #  And store it in the register (without popping)
       ×       #  Repeat character `y` that input amount of times
        U      #  Pop and store that string in variable `X`
    εX.ø}      #  Surround each string in the list with string `X`
    ®F         #  Inner loop the value from the register amount of times:
      Dнg      #   Get the new width by taking the length of the first string
         y×    #   Repeat character `y` that many times
             #   And surround the list with this leading and trailing string
   ]           # Close both the inner and outer loops
    S         # Convert each inner string to a list of characters
      »        # Join every list of characters by spaces, and then every string by newlines
               # (and output the result implicitly)
Кевин Круйссен
источник
1

Python 3.8 (предварительная версия) , 116 115 113 байтов

lambda a,b,c,d:"\n".join((g:=['#'*(a+2*c+2*d)]*d+[(h:='#'*d)+'+'*(a+c*2)+h]*c)+[h+'+'*c+'X'*a+'+'*c+h]*b+g[::-1])

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

Первая попытка игры в гольф скоро будет улучшена. aэто ширина, bвысота, cматовая ширина и dширина кадра.

-1 байт, используя :=оператор для определения hкакe * d

-2 байта благодаря Джо Кингу, предложившему мне удалить параметры e и f

ОБЪЯСНЕНИЕ:

lambda a,b,c,d:          Define a lambda which takes in arguments a, b, c, and d (The width of the painting, the height of the painting, the padding of the matte, and the padding of the frame width, respectively).
    "\n".join(                       Turn the list into a string, where each element is separated by newlines
        (g:=                         Define g as (while still evaling the lists)...
            ['#'*(a+2*c+2*d)]*d+       Form the top rows (the ones filled with hashtags)
            [(h:='#'*d)+'+'*(a+c*2)+h]*c Form the middle-top rows (uses := to golf this section)
        )+
        [h+'+'*c+'X'*a+'+'*c+h]*b+       Form the middle row
        g[::-1]                      Uses g to golf the code (forms the entire middle-bottom-to-bottom)
    )
MilkyWay90
источник
Удаление eназначения экономит вам два байта, fназначение ничего не спасает
Джо Кинг
@JoKing Ого, я забыл удалить eи fназначения после обнаружения gярлыка
MilkyWay90
0

Javascript, 158 байт

(w,h,m,f)=>(q="repeat",(z=("#"[q](w+2*(m+f)))+`
`)[q](f))+(x=((e="#"[q](f))+(r="+"[q](m))+(t="+"[q](w))+r+e+`
`)[q](m))+(e+r+"X"[q](w)+r+e+`
`)[q](h)+x+z)

Может быть, можно немного урезать

f=

(w,h,m,f)=>(q="repeat",(z=("# "[q](w+2*(m+f))+`
`)[q](f))+(x=((e="# "[q](f))+(r="+ "[q](m))+(t="+ "[q](w))+r+e+`
`)[q](m))+(e+r+"X "[q](w)+r+e+`
`)[q](h)+x+z)

console.log(f(3,2,1,2))

vityavv
источник
0

Perl 6 , 98 байт

{map(&min,[X] map (($_='#'x$^d~'+'x$^c)~'X'x*~.flip).comb,$^a,$^b).rotor($b+2*($c+$d)).join("\n")}

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

Это порт ответа xnor на Python .

Perl 6 , 115 байт

->\a,\b,\c,\d{$_=['#'xx$!*2+a]xx($!=c+d)*2+b;.[d..^*-d;d..^a+$!+c]='+'xx*;.[$!..^*-$!;$!..^a+$!]='X'xx*;.join("
")}

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

Грубый анонимный кодовый блок с использованием многопланового списка Perl 6. Например, @a[1;2] = 'X';назначит 'X'элемент с индексом 2 из списка с индексом 1 и @a[1,2,3;3,4,5]='X'xx 9;заменит все элементы с индексами 3,4,5списков с индексами 1,2,3с 'X'.

Объяснение:

Во- первых, мы инициализируем список в виде a+2*(c+d)по b+2*(c+d)прямоугольнику #с.

$_=['#'xx$!*2+a]xx($!=c+d)*2+a;
State:
# # # # # # # # #
# # # # # # # # #
# # # # # # # # #
# # # # # # # # #
# # # # # # # # #
# # # # # # # # #
# # # # # # # # #
# # # # # # # # #

Затем мы назначаем внутренний прямоугольник +s

.[d..^*-d;d..^a+$!+c]='+'xx*;
State:
# # # # # # # # #
# # # # # # # # #
# # + + + + + # #
# # + + + + + # #
# # + + + + + # #
# # + + + + + # #
# # # # # # # # #
# # # # # # # # #

Наконец, самый внутренний прямоугольник Xs.

.[$!..^*-$!;$!..^a+$!]='X'xx*;
# # # # # # # # #
# # # # # # # # #
# # + + + + + # #
# # + X X X + # #
# # + X X X + # #
# # + + + + + # #
# # # # # # # # #
# # # # # # # # #
Джо Кинг
источник
0

Желе , 35 31 28 24 байта

Dịx@“#+X+#”
⁽-Fç«þ⁽-ȥç$G

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

Берет на вход в порядке рамки, мат, ширина, высота; разделенные запятой. Выводит изображение ASCII-art с рамкой и матовой поверхностью. Если порядок ввода строгий, мне нужно было бы добавить больше байтов (согласно моему исходному сообщению).

Пара гольфов на основе ответа @ EriktheOutgolfer; Я понял, что персонажи были в порядке ASCII, но не думал, как лучше этим воспользоваться, и забыл об этом G. Его все еще лучший ответ, хотя!

Ник Кеннеди
источник
Я никогда не программирую на желе, но наверняка можно сжать 43134,43234? РЕДАКТИРОВАТЬ: Мне нужно научиться читать, вы упоминаете, что они действительно могут быть закодированы в 4 байта каждый. Но при чем тут порядок ввода, можно ли закодировать эти числа или нет? : S
Кевин Круйссен
@KevinCruijssen максимальное целое число, которое может быть закодировано с использованием двухбайтового синтаксиса, равно 32250; поскольку оба превышают это, я не могу сохранить байты. Сейчас я предполагаю, что могу поменять вещи и вернуться, если это не разрешено!
Ник Кеннеди
Ах, хорошо, я вижу. 43134потребуется 3 кодирующих символа, которые, включая начальный / завершающий символ, чтобы указать, что он закодирован, также будут иметь 5 байтов. И, возможно, у желе есть какой-то дубликат, поскольку второе число на 100 больше первого? Не уверены, что в желе возможны и коротки действия push 43134, duplicate, push 100, plus, pair ?
Кевин Круйссен
@KevinCruijssen Я изначально пробовал это, используя +0,100, который не спасает ни одного. Я думаю, что я мог бы использовать цепочку nilad, чтобы использовать тот факт, что в nilad ³ есть 100, но если мне разрешено переупорядочивать входы, то базовые 250 целых чисел лучше
Ник Кеннеди
0

Perl 5, 115 байт

$_=(X x$F[0].$/)x$F[1];sub F{s,^|\z,/.*/;$_[0]x"@+".$/,ge,s/^|(?=
)/$_[0]/gm while$_[1]--}F('+',$F[2]);F('#',$F[3])

TIO

Науэль Фуйе
источник