Построить простую комнату в ASCII-арт

15

Комната может состоять из соединенных прямоугольников, например, L-образная комната. Такая комната может быть описана списком измерений, описывающих размер каждого прямоугольника.

Предположим, у вас есть два списка ввода. Первый содержит ширину прямоугольников, сложенных вертикально друг над другом. Второй содержит высоту прямоугольников.

Например, ввод [4 6][3 2]будет прямоугольником 4 на 3 поверх прямоугольника 6 на 2. На рисунке ниже показана эта форма. Обратите внимание, что стены считаются «тонкими», поэтому пространство между стенами определяется входными данными.

[4 6][3 2]
 ____
|    |
|    |
|    |_
|      |
|______|

Задача состоит в том, чтобы: взять список измерений в качестве входных данных и вывести форму комнаты как ASCII-art. Формат должен быть таким, как на примерах рисунков:

  • Все горизонтальные стены показаны с помощью подчеркивания
  • Все вертикальные стены показаны с помощью баров
  • Там не должно быть стен, где соединены прямоугольники
  • Левая стена прямая
  • Для более подробной информации, посмотрите на тестовые случаи

Предположения, которые вы можете сделать:

  • Все размеры в ассортименте [1 ... 20]
    • Все горизонтальные размеры четные числа
  • Количество прямоугольников будет в диапазоне [1 ... 10]
  • Дан только действительный ввод
  • Необязательный формат ввода (вы можете решить порядок входных размеров, пожалуйста, укажите в ответе).

Тестовые случаи:

[2][1]
 __
|__|

---

[4][2]
 ____
|    |
|____|

---

[2 6 2 4][2 2 1 3]
 __
|  |
|  |___
|      |
|   ___|
|  |_
|    |
|    |
|____|

---

[2 14 6 8 4 18 2 10 4 2][1 2 3 1 2 1 1 1 2 1]
 __
|  |___________
|              |
|       _______|
|      |
|      |
|      |_
|     ___|
|    |
|    |_____________
|   _______________|
|  |______
|     ____|
|    |
|   _|
|__|
Стьюи Гриффин
источник
Вы можете решить порядок входных измерений , означает ли это, что мы можем поменять местами строки и столбцы и повернуть их вспять? Вот так: ваш пример формата ввода: [2 14 6 8 4 18 2 10 4 2][1 2 3 1 2 1 1 1 2 1]-> (поменять местами и обратно) -> мой формат ввода:[1 2 1 1 1 2 1 3 2 1][2 4 10 2 18 4 8 6 14 2]
daavko
Да, все в порядке. :-)
Стьюи Гриффин
Благодарю. Оказалось, мне, вероятно, не нужно менять их, просто поменяйте местами.
Даавко

Ответы:

1

Сетчатка, 169 150 113 байтов

Количество байтов предполагает кодировку ISO 8859-1.

\ D +
$ *
{+ R`1 (1 * ¶ [^ |] * (1+))
$ 1¶ | $ 2 |
} `(¶. *) 1+
$ 1
1
_
(\ | _ +) \ | (? = ¶ \ 1 _ (_ +))
$ 1 | $ 2
T`w` `(\ | _ +) _? (? = _ * \ |. * ¶ \ 1)
^ ¶
 

Код содержит завершающий пробел в конце новой строки.

Формат ввода:

Высота (разделенная пробелами)
Ширина (также разделенная пробелами)

Например:

1 2 3 1 2 1 1 1 2 1
2 14 6 8 4 18 2 10 4 2

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

daavko
источник
4

JavaScript (ES6) 174

Единственная критическая часть - это горизонтальный ряд, соединяющий 2 части различной ширины, с вертикальной полосой на правой стороне, которая может быть посередине или на правом конце.

(p,h,q=-1,R=(n,s=' ')=>s.repeat(n))=>[...p,0].map((x,i)=>(x>q?p=x:(p=q,q=x),(~q?`
|`+R(q+(x<p)-!x)+R(x>q,'|'):' ')+R(p+~q+!x,'_')+R(x<p,'|')+R(h[i]-1,`
|${R(q=x)}|`))).join``

ТЕСТОВОЕ ЗАДАНИЕ

f=(p,h,q=-1,R=(n,s=' ')=>s.repeat(n))=>[...p,0].map((x,i)=>(x>q?p=x:(p=q,q=x),(~q?`
|`+R(q+(x<p)-!x)+R(x>q,'|'):' ')+R(p+~q+!x,'_')+R(x<p,'|')+R(h[i]-1,`
|${R(q=x)}|`))).join``

// Less golfed

F=(p,h, q=-1, 
   R=(n,s=' ')=>s.repeat(n)
  )=>
  [...p, 0].map((x,i)=> (
    x>q? p=x : (p=q,q=x),
    (q>=0?`\n|`+R(q+(x<p)-!x)+R(x>q,'|'):' ')
    + R(p+~q+!x,'_') + R(x<p,'|')
    + R(h[i]-1,`\n|${R(q=x)}|`)
  )).join``

console.log=x=>O.textContent+=x+'\n'

;[  
  [[2],[1]],
  [[4],[2]],
  [[2, 6, 2, 4],[2, 2, 1, 3]],
  [[2, 14, 6, 8, 4, 18, 2, 10, 4, 2],[1, 2, 3, 1, 2, 1, 1, 1, 2, 1]]
].forEach(t=>{
  var w=t[0],h=t[1]
  console.log('['+w+'] ['+h+']\n'+f(w,h)+'\n')
})
<pre id=O></pre>

edc65
источник
4

Python 3, 230 223 222 217 байт

def f(a):b=a[0]+[0];m=' _';print('\n'.join([' '+'_'*b[0]+' ']+['|'+' '*min(b[l],b[l+1])+m[b[l+1]<1]*(b[l]>b[l+1])+m[k]*(b[l]-b[l+1]-1)+'|'+m[k]*(b[l+1]-b[l]-1)for l,i in enumerate(zip(*a))for k in[0]*(i[1]-1)+[1]]))

Спасибо @StewieGriffin @KevinLau за помощь

Результаты

>>> f([[2, 14, 6, 8, 4, 18, 2, 10, 4, 2],[1, 2, 3, 1, 2, 1, 1, 1, 2, 1]])
 __ 
|  |___________
|              |
|       _______|
|      | 
|      | 
|      |_
|     ___|
|    |             
|    |_____________
|   _______________|
|  |_______
|     _____|
|    |
|   _|
|__|
Эрвана
источник
! Запятой Они отделяют ваши задания и спасают вас от нежелательных отступов! ( a=1;b=2)
CalculatorFeline
"solutoin"> решение
Мэтт
Строка индексации! m=' _'вместо m=[' ','_']сохранения как 5 байтов.
Value Ink
3

Рубин 191

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

def f(x)
a=x[0]+[0]
puts" #{'_'*a[0]} "
for i in 0..x[1].length-1
n,m=a[i,2].sort
puts"|#{' '*a[i]}|\n"*(x[1][i]-1)+'|'+' '*n+(a[i+1]<1?'_':m>a[i]?'|':' ')+'_'*(m-n-1)+(n<a[i]?'|':'')
end
end
Значение чернил
источник