Imprima-me um bloco de torre


16

Imprima um bloco de torre com o menor código possível.

Entrada:

A entrada define quantos andares o bloco da torre possui. Um andar contém uma janela em ambos os lados da porta. A janela é composta de hashes 3x3.

Um exemplo de um bloco de torre de 4 andares está abaixo:

      =====================
      )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 : : : : :

Atualizar:

A entrada deve ser uma ou mais.

Espaços à direita no final das linhas são permitidos.

No meu exemplo, cada linha tem três espaços à esquerda. Isso não é obrigatório, apenas o bloco de torre com a entrada é.


2
A entrada pode ser menor que 1?
nmjcman101

2
Os espaços finais no final das linhas são permitidos?
Ngenisis

Obrigado pelas suas perguntas - consulte a atualização na minha pergunta.
Belfield

Respostas:


6

V , 72 bytes

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

Experimente online!

Aqui está um hexdump, pois contém caracteres não imprimíveis:

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

Encontrei um bug estranho. A seção no meio: dGÀpGdeveria ter sido:, ÀäGGmas isso não funciona para as entradas 1, e não faço ideia do porquê.¯\_(ツ)_/¯


8

Mathematica, 301 288 258 bytes

" "~(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}&

Função pura que pega um número inteiro positivo e gera uma string. A string de saída não parecerá correta porque o Mathematica aparentemente não exibe fontes monoespaçadas como monoespaço:

insira a descrição da imagem aqui

Por razões que eu não entendo direito, ele formata como monoespaço se você for Printa string:

insira a descrição da imagem aqui

Editar: salvou vários bytes por não incluir " "no início de cada linha. Mudou a definição de slidar com o caso em que há apenas um andar ( StringRepeatnão gosta de repetir uma sequência de 0vezes).

Edit 2: Graças à LegionMammal978 eo fato de que StringJoiné Listable, este é agora um pesadelo incompreensível de listas aninhadas e também 30 bytes mais curto.


1
Pelo menos 26 bytes podem ser salvos substituindo a<>b<>...<>x-os a<>{b,...,x}por certas partes.
usar o seguinte

4

Python 2 , 275 270 262 246 240 236 bytes

Salvei um casal com uma dica de @ Flp.Tkc e alterando o primeiro loop for.

16 salvos com mais ajuda de @ 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]])

Experimente online!

Apenas constrói cada linha da torre como uma string e a adiciona a uma matriz, para que imprima a matriz no final. Se alguém quiser uma explicação completa, eu relutantemente darei se consigo lembrar como isso funciona ☺


3

PowerShell , 193 bytes

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

Experimente online!

(Eu sinto que ainda pode haver alguns bytes aqui ou ali. Sub-190 parece factível.)

As três primeiras linhas formam o telhado, usando multiplicação e concatenação de cordas, juntamente com um loop 3..0|%{...}para obter o número correto e a inclinação de Vs.

A próxima linha vai da entrada pré-decrementada --$args[0]até 0como um loop (o pré-decremento nos permite indexar usando em !$_vez de $_-eq1salvar vários bytes posteriormente). A cada iteração de loop, estamos construindo um monte de strings, definindo variáveis $be $aao longo do caminho. Também estamos usando pseudo-ternários (... , ...)[...]para escolher as cordas apropriadas para o meio, para que possamos corrigir a porta do primeiro andar.

Cada uma das seqüências é deixada individualmente no pipeline, e o padrão Write-Outputinsere novas linhas entre elas, para que possamos obtê-las gratuitamente.


3

T-SQL, 378 372 353 331 325 bytes

Golfe:

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

Experimente


2

C, 409 406 402 bytes

#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);}

Ligue para:

int main()
{
    t(4);
}

1

Lote, 373 bytes

@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%

Constrói a cordilheira e a sarjeta ao perceber que são múltiplos de 3, o que reduz alguns bytes. Constrói o telhado observando que o sufixo é o mesmo para cada linha (e novamente inclui algumas repetições em três partes). Constrói as paredes, começando com a linha de parede mais interessante, que é a janela do térreo, e removendo detalhes para gerar as outras partes da parede.


1

Javascript, 335 bytes

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)};

Cria uma função y()com argumento z, tal que y(z)produz a saída desejada.

Exemplo de uso:

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));

Estou fazendo a transição do JavaScript normal para o JS de código-golfe. Quaisquer dicas seriam extremamente apreciadas.


1

Tela , 62 61 bytes

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

Experimente aqui! A entrada 0 funciona conforme o esperado, mesmo que isso não seja necessário.


ei, como a altura da casa é modificada usando esse script?
t-clausen.dk

Meus olhos antigos
estavam errados
Ao utilizar nosso site, você reconhece que leu e compreendeu nossa Política de Cookies e nossa Política de Privacidade.
Licensed under cc by-sa 3.0 with attribution required.