Напечатай мне башенный блок


16

Напечатайте башенный блок с кратчайшим кодом.

Входные данные:

Вход определяет, сколько этажей имеет башенный блок. Один этаж содержит окно с обеих сторон двери. Окно состоит из хэшей 3х3.

Пример 4-х этажного башенного блока ниже:

      =====================
      )V V V V V V V V V V(
     )V V V V V V V V V V V(
    )V V V V V V V V V V V V(
   )V V V V V V V V V V V V V(
   ~~~~~~~~~~~~~~~~~~~~~~~~~~~
   : : : : : : : : : : : : : :
   : : ### : : : : : : ### : :
   : : ### : : : : : : ### : :
   : : ### : : : : : : ### : :
   : : : : : : : : : : : : : :
   : : : : : : : : : : : : : :
   : : ### : : : : : : ### : :
   : : ### : : : : : : ### : :
   : : ### : : : : : : ### : :
   : : : : : : : : : : : : : :
   : : : : : : : : : : : : : :
   : : ### : : : : : : ### : :
   : : ### : : : : : : ### : :
   : : ### : : : : : : ### : :
   : : : : : : : : : : : : : :
   : : : : : _______ : : : : :
   : : ### : I     I : ### : :
   : : ### : I     I : ### : :
   : : ### : I     I : ### : :
   : : : : : I     I : : : : :

Обновить:

Ввод должен быть один или больше.

Конечные пробелы в конце строк разрешены.

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


2
Может ли ввод быть меньше 1?
nmjcman101

2
Разрешены ли пробелы в конце строк?
ngenisis

Спасибо за ваши вопросы - смотрите обновление в моем вопросе.
Belfield

Ответы:


6

V , 72 байта

13iV r(É)3ñįlxñÄ21r=GÙÒ~Ù14R: ÙÄ2w3r#7w.3ÄkdGÀpG4k5w7r_bêojrIÎfIl5r 

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

Вот hexdump, так как он содержит непечатаемые символы:

00000000: 3133 6956 201b 7228 c929 33f1 c4af 6c78  13iV .r(.)3...lx
00000010: f1c4 3231 723d 47d9 d27e d931 3452 3a20  ..21r=G..~.14R: 
00000020: 1bd9 c432 7733 7223 3777 2e33 c46b 6447  ...2w3r#7w.3.kdG
00000030: c070 4734 6b35 7737 725f 1662 ea6f 6a72  .pG4k5w7r_.b.ojr
00000040: 49ce 6649 6c35 7220                      I.fIl5r

Я столкнулся со странной ошибкой. Раздел в середине: dGÀpGдолжен был быть:, ÀäGGно это не работает для входов 1, и я понятия не имею, почему.¯\_(ツ)_/¯


8

Mathematica, 301 288 258 байт

" "~(s=If[#2==0,"",#~StringRepeat~#2]&)~3<>{"="~s~21,"
",s[" ",12-#]<>{")","v "~s~#,"v(
"}&/@9~Range~12,"~"~s~27,"
",s[(x=(u=": ")~s~13<>":
")<>{y=u<>{z=": ### ",v=u~s~5,w=z<>": :
"},y,y,x},#-1],v,"_"~s~7," ",v,"
",m=u<>{z,u,n="I     I ",w},m,m,v,n,w}&

Чистая функция, которая принимает положительное целое число и выводит строку. Выходная строка не будет выглядеть правильно, потому что Mathematica явно не отображает моноширинные шрифты как моноширинные:

введите описание изображения здесь

По причинам, которые я не совсем понимаю, он форматируется как моноширинный, если вы Printстроку:

введите описание изображения здесь

Изменить: Сохранение нескольких байтов, не включая " "в начале каждой строки. Изменено определение sдля обработки случая, когда есть только один этаж ( StringRepeatне любит повторять строку 0раз).

Изменить 2: Благодаря LegionMammal978 и тот факт , что StringJoinэтоListable , это теперь непонятная кошмар вложенных списков , а также 30 байт короче.


1
По крайней мере , 26 байт могут быть сохранены путем замены a<>b<>...<>xс a<>{b,...,x}в некоторых частях.
LegionMammal978

4

Python 2 , 275 270 262 246 240 236 байт

Спасла пару с подсказкой от @ Flp.Tkc и изменив первый цикл for.

16 сохранено с дополнительной помощью от @ Flp.Tkc

a,h,b,c,w=' ',"I  ",": "," :","#"*3;d,e,j=b*2+w+a+b+h,b*5+h,[b*14]
print'\n'.join([a*3+'='*21]+[a*(4-x)+')'+'V '*(x+8)+'V('for x in 1,2,3,4]+['-'*27]+(j+[b*2+w+c*6+a+w+c*2]*3+j)*(input()-1)+[b*5+"_"*7+c*5]+[d+a+d[::-1]]*3+[e+a+e[::-1]])

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

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


3

PowerShell , 193 байта

"   "+"="*21
3..0|%{" "*$_+")"+"V "*(12-$_)+"V("}
"~"*27
--$args[0]..0|%{($b=": "*5)+(($a=": "*4),'_______ ')[!$_]+$b;,(': : ### : '+($a,($c='I     I '))[!$_]+': ### : :')*3;$b+($a,$c)[!$_]+$b}

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

(Я чувствую, что здесь или там еще может быть несколько байтов. Sub-190 кажется выполнимым.)

Первые три строки образуют крышу, используя умножение и конкатенацию строк, а также цикл, 3..0|%{...}чтобы получить правильное число и наклонV s.

Следующая строка проходит от входа предварительно уменьшается --$args[0]до 0как цикл (предварительно декремент позволяет индексировать , используя !$_вместо того , чтобы $_-eq1экономить несколько байт позже). На каждой итерации цикла мы создаем кучу строк, устанавливаем переменные $bи $aпо пути. Мы также используем псевдо-тройки, (... , ...)[...]чтобы выбрать подходящие струны для середины, чтобы мы могли правильно определить дверной проем на первом этаже.

Каждая строка остается отдельно в конвейере, и по умолчанию Write-Outputвставляются новые строки между ними, поэтому мы получаем их бесплатно.


3

T-SQL, 378 372 353 331 325 байт

Golfed:

DECLARE @ INT=3

,@h varchar(max)=REPLICATE('~',27)SELECT @h+='
: '+a+IIF(n>@*5-6,IIF(n%5=0,'_______ ','I     I '),t)+a+':'FROM(SELECT
IIF(n%5%4=0,t,': ### : ')a,*FROM(SELECT': : : : 't,number n,*FROM spt_values)x)y
WHERE type='P'and n<@*5SET @=0WHILE @<4SELECT
@h=SPACE(@)+')'+REPLICATE('V ',12-@)+'V(
'+@h,@+=1PRINT'   '+REPLICATE('=',21)+'
'+@h

Ungolfed:

DECLARE @ INT=3

,@h varchar(max)=REPLICATE('~',27)
SELECT @h+='
: '+a+IIF(n>@*5-6,IIF(n%5=0,'_______ ','I     I '),t)+a+':'
FROM
(SELECT IIF(n%5%4=0,t,': ### : ')a,*
FROM
(SELECT': : : : 't,number n,*
FROM spt_values)x)y
WHERE type='P'and n<@*5
WHILE @>=0
  SELECT @h=SPACE(3-@)+')'+REPLICATE('V ',9+@)+'V(
'+@h,@-=1
PRINT'   '+REPLICATE('=',21)+'
'+@h

Попробуйте это


2

C 409 406 402 байта

#define P(x)p(": ",x);
#define S(x)p(x,1);
#define L P(2)p("#",3);p(" :",6);S(" ###");S(" : :\n")
#define Q p("V ",i+++9)
p(s,n)char*s;{printf(s,--n?p(s,n):0);}i;t(n){p(" ",3);p("=",21);S("\n   )")Q;S("V(\n  )")Q;S("V(\n )")Q;S("V(\n)")Q;S("V(\n")p("~",27);S("\n")for(;--n;){P(13)S(":\n")L;L;L;P(13)S(":\n")}P(5)p("_",7);p(" :",5);S("\n")p(": : ### : I     I : ### : :\n",3);P(5)S("I     I")p(" :",5);}

Звоните с:

int main()
{
    t(4);
}

1

Пакетный, 373 байта

@echo off
set s=###
echo    %s:#========%
for %%s in ("   )" "  )V " " )V V " ")V V V ")do echo %%~sV%s:#= V V V%(
echo %s:#=~~~~~~~~~%
set t=: : ### : I     I : ### : :
set s=%t:I     I=: : : :%
for /l %i in (2,1,%1)do echo %s:###=: :%&echo %s%&echo %s%&echo %s%&echo %s:###=: :%
set s=%t:###=: :%
echo %s:I     I=_______%
echo %t%
echo %t%
echo %t%
echo %s%

Строит гребень и желоб, замечая, что они кратны 3, что сбрасывает несколько байтов. Строит крышу, замечая, что суффикс является одинаковым для каждой строки (и снова включает в себя несколько тройных повторений). Строит стены, начиная с самой интересной линии стены, которая является окном первого этажа, и удаляя детали, чтобы создать другие части стены.


1

Javascript, 335 байт

y=z=>{a="   "+"=".repeat(21);for(b=9;13>b;b++)a+="\n"+" ".repeat(12-b)+")"+"V ".repeat(b)+"V(";a+="\n"+"~".repeat(27);b="\n"+": ".repeat(14);c=": : ### : : : : : : ### : :";for(d=0;d<z-1;d++)a+=b+"\n"+c+"\n"+c+b;a+="\n: : : : : _______ : : : :\n"+": : ### : I     I : ### : :\n".repeat(3)+": : : : : I     I : : : : :";console.log(a)};

Создает функцию y()с аргументом z, которая y(z)производит желаемый результат.

Пример использования:

y=z=>{a="   "+"=".repeat(21);for(b=9;13>b;b++)a+="\n"+" ".repeat(12-b)+")"+"V ".repeat(b)+"V(";a+="\n"+"~".repeat(27);b="\n"+": ".repeat(14);c=": : ### : : : : : : ### : :";for(d=0;d<z-1;d++)a+=b+"\n"+c+"\n"+c+b;a+="\n: : : : : _______ : : : :\n"+": : ### : I     I : ### : :\n".repeat(3)+": : : : : I     I : : : : :";console.log(a)};

console.log(y(3));

Я перехожу с обычного JavaScript на код-гольф JS. Любые советы будут с благодарностью.


1

Холст , 62 61 байт

⁶=⁵×V7× * )×4*∔/‾²m~7«× ×∔│8 ×:*5*#33*62╋│⁸*∔l4-_7× 5×Ie4*∔╋╋

Попробуй это здесь! Вход 0 работает как положено, хотя это и не обязательно.


эй, как высота дома изменяется с помощью этого скрипта?
t-clausen.dk

Мои старые глаза пропустили номер в правом поле
t-clausen.dk
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.