Рендеринг ASCII Box


11

задача

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

вход

Вам будет предоставлен список номеров. Формат здесь немного гибкий, в том , что вы можете использовать любой deliminator вы хотите (например 1,2,3,4, 1 2 3 4, [1,2,3,4]). Список состоит из 4 групп и определяет xywhкаждый из полей. Ширина и высота каждой ячейки будет не менее 2 xи widthслева направо. yи heightсверху вниз.

Выход

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

Как обрабатывать перекрывающиеся коробки

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

Стиль

Стиль ящиков довольно стандартный, +используется для углов, -для горизонтальных линий и |для вертикальных линий.

Примеры:

( >>>обозначает ввод)

>>>0 0 11 4 7 2 8 4 3 5 8 3
+---------+
|         |
|         |---+
+---------+   |
       |      |
   +---+------+
   |      |
   +------+


>>>0 3 11 4 7 5 8 4 3 8 8 3 4 0 13 5
    +-----------+
    |           |
    |           |
+---------+     |
|         |-----+
|         |---+
+---------+   |
       |      |
   +---+------+
   |      |
   +------+


>>>0 0 2 2
++
++


>>>2 2 5 3 1 1 7 5 0 0 9 7
+-------+
|+-----+|
||+---+||
|||   |||
||+---+||
|+-----+|
+-------+

>>>0 0 3 3 2 0 3 3
+-+-+
| | |
+-+-+

Не должен ли этот средний быть 4 0 13 5чем 0 4 13 5?
Нил

2-й прямоугольник снизу в первых двух случаях имеет x = 7 (чтобы соответствовать прямоугольникам x = 0)
Уровень River St

1
Спасибо, что заметили, я редко пишу ответы на свои вопросы, и поэтому все это вручную ...
J Atkin

@JAtkin Извините, я пропустил это.
Конор О'Брайен

Это хорошо, я часто скучаю по вещам, когда читаю;)
J Аткин

Ответы:


4

APL, 116 байт

{⎕IO←0⋄K←' '⍴⍨⌽+⌿2 2⍴⌈⌿↑⍵⋄K⊣{x y W H←⍵-⌊.5×⍳4⋄K[Y←y+⍳H;X←x+⍳W]←' '⋄K[Y;A←x+0 W]←'|'⋄K[B←y+0 H;X]←'-'⋄K[B;A]←'+'}¨⌽⍵}

Это функция, которая принимает массив массивов и возвращает матрицу символов.

тесты:

      t1← (0 0 11 4)(8 2 8 4)(3 5 8 3)
      t2← (0 3 11 4)(8 5 8 4)(3 8 8 3)(4 0 13 5)
      t3← (⊂0 0 2 2)
      t4← (2 2 5 3)(1 1 7 5)(0 0 9 7)
      {⎕IO←0⋄K←' '⍴⍨⌽+⌿2 2⍴⌈⌿↑⍵⋄K⊣{x y W H←⍵-⌊.5×⍳4⋄K[Y←y+⍳H;X←x+⍳W]←' '⋄K[Y;A←x+0 W]←'|'⋄K[B←y+0 H;X]←'-'⋄K[B;A]←'+'}¨⌽⍵} ¨ t1 t2 t3 t4
┌───────────────────┬─────────────────────┬────┬───────────┐
│+---------+        │    +-----------+    │++  │+-------+  │
│|         |        │    |           |    │++  │|+-----+|  │
│|         |----+   │    |           |    │    │||+---+||  │
│+---------+    |   │+---------+     |    │    │|||   |||  │
│        |      |   │|         |-----+    │    │||+---+||  │
│   +----+------+   │|         |----+     │    │|+-----+|  │
│   |      |        │+---------+    |     │    │+-------+  │
│   +------+        │        |      |     │    │           │
│                   │   +----+------+     │    │           │
│                   │   |      |          │    │           │
│                   │   +------+          │    │           │
│                   │                     │    │           │
│                   │                     │    │           │
└───────────────────┴─────────────────────┴────┴───────────┘

Объяснение:

  • ⎕IO←0: установите начало индекса в 0.
  • Создайте матрицу нужного размера:
    • ⌈⌿↑⍵: найти самые большие значения для x, y, w и h
    • +⌿2 2⍴: x + w и y + h
    • K←' '⍴⍨⌽: сделать матрицу из x + w * y + h пробелов и сохранить ее в K.
  • Нарисуйте коробки в это:
    • {... }¨⌽⍵: для каждого из ящиков в обратном порядке,
      • x y W H←⍵-⌊.5×⍳4: Назначить координаты на x, y, W, и H, и вычесть 1 из обоего Wи H. (координаты являются исключительными, диапазоны массива APL включительно.)
      • K[Y←y+⍳H;X←x+⍳W]←' ': заполните текущее поле пробелами
      • K[Y;A←x+0 W]←'|': нарисовать вертикальные стороны
      • K[B←y+0 H;X]←'-': нарисовать горизонтальные стороны
      • K[B;A]←'+': установите края в '+'
    • K⊣: потом вернитесь K.

1
APL - такой странно выглядящий язык для постороннего ...
Дж Аткин

3

ES6, 228 223 217 208 201 198 байтов

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

a=>a.reverse().map(([x,y,w,h])=>[...Array(y+h)].map((_,i)=>(s=r[i]||'',r[i]=i<y?s:(s+' '.repeat(x)).slice(0,x)+(c=>c[0]+c[1].repeat(w-2)+c[0])(y-i&&y+h-1-i?'| ':'+-')+s.slice(x+w))),r=[])&&r.join`\n`

Где \nпредставляет символ новой строки.

Изменить: 5 байтов, изменив мои условия. Сохранение дополнительных 6 байтов путем переключения с массива массивов символов на массив строк. Сохранено еще 9 байтов, введя временную переменную. Сохранено еще 7 байтов, введя вспомогательную функцию. Сохранены еще 3 байта, отменив предыдущее сохранение!


3

Рубин, 153 143

->n{a=(0..m=3*n.max).map{$b=' '*m}
(*n,x,y,w,h=n 
v=w-2
h.times{|i|a[y+i][x,w]=i%~-h<1??++?-*v+?+:?|+' '*v+?|}
)while n[0]
a.delete($b);puts a}

Неуправляемый в тестовой программе

f=->n{                                #worst case width when x=w=large number, is max input*2+1
  a=(1..m=3*n.max).map{$b=' '*m}      #find m=max value in input, make an a array of 3*m strings of 3*m spaces 
  (
    *n,x,y,w,h=n                      #extract x,y,w,h from the end of n, save the rest back to n     
    v=w-2                             #internal space in rectangle is w-2  
    h.times{|i|                       #for each row
      a[y+i][x,w]=                    #substitute the relevant characters of the relevant lines of a 
      i%~-h<1?                        #i%~-h = i%(h-1). This is zero (<1) for first and last lines of the rectangle
      ?+ + ?-*v + ?+ :?| + ' '*v +?|  # +--...--+ or |  ...  | as required
    }
  )while n[0]                         #loop until data exhausted (n[0] becomes falsy as it does not exist)
a.delete($b);puts a}                  #delete blank rows ($b is a global variable) and display

3

SmileBASIC, 128 125 байт

DEF B A
WHILE LEN(A)H=POP(A)W=POP(A)-2Y=POP(A)X=POP(A)FOR I=0TO H-1LOCATE X,Y+I?"+|"[M];"- "[M]*W;"+|"[M]M=I<H-2NEXT
WEND
END

Скриншоты (обрезано)

снимок экрана снимок экрана снимок экрана снимок экрана снимок экрана

объяснение

DEF B A 'make a function and add 12 bytes :(
 WHILE LEN(A) 'repeat until array is empty
  H=POP(A):W=POP(A)-2 'get width/height
  Y=POP(A):X=POP(A) 'get x/y
  FOR I=0 TO H-1 'draw one row at a time
   LOCATE X,Y+I 'position the cursor
   PRINT "+|"[M]; 'draw left edge
   PRINT "- "[M]*W; 'draw middle
   PRINT "+|"[M] 'draw right edge
   M=I<H-2
  NEXT
 WEND
END

Mхранит ли он в первой / последней строке поля ( 0= +--+, 1= | |). На первом проходе через цикл M- 0, а на всех остальных до последнего - 1.


Это очень мило :)
J Atkin

Мета-консенсус заключается в том, что вы не можете принимать данные из предопределенных переменных .
FlipTack

1

Pyth, 162 145 байтов

J\+K*h.MZm+@d1@d3Q]*h.MZm+@d0@d2QdD:GHb XKHX@KHGb;V_QDlTR@NTVl3Vl2:+l0b+l1H?|qHtl3qH0\-?|qbtl2qb0\|d)):l0l1J:+l0tl2l1J:l0+l1tl3J:+l0tl2+l1tl3J;jK

Вы можете попробовать это здесь

Вывод набора тестов:

+---------+     
|         |     
|         |----+
+---------+    |
        |      |
   +----+-+----+
   |      |     
   +------+     

++
++

+-------+
|+-----+|
||+---+||
|||   |||
||+---+||
|+-----+|
+-------+

+-+-+
| | |
+-+-+

Ужасное решение! Просто жду, когда кто-то победит


2
Ваш первый пример добавляет дополнительный +, где ящики имеют общий край.
Линус
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.