Imprimir o foguete retrô

13

(inspirado nesta pergunta do SO )

Você recebe como entrada um único número inteiro positivo n .

No menor número de caracteres possível, produza um foguete na arte ASCII com uma cabeça, uma cauda e um corpo composto por n segmentos. Não deve haver espaços à direita ou novas linhas.

A cabeça e a cauda do foguete são sempre as mesmas para qualquer valor de n . O corpo consiste em dois tipos diferentes de segmentos que se alternam. Os exemplos devem deixar clara a estrutura do foguete.

Saída para n = 1:

     /**\
    //**\\
   ///**\\\
  ////**\\\\
 /////**\\\\\
+=*=*=*=*=*=*+
|\/\/\/\/\/\/|
|.\/\/..\/\/.|
|..\/....\/..|
|../\..../\..|
|./\/\../\/\.|
|/\/\/\/\/\/\|
+=*=*=*=*=*=*+
     /**\
    //**\\
   ///**\\\
  ////**\\\\
 /////**\\\\\

Saída para n = 2:

     /**\
    //**\\
   ///**\\\
  ////**\\\\
 /////**\\\\\
+=*=*=*=*=*=*+
|../\..../\..|
|./\/\../\/\.|
|/\/\/\/\/\/\|
|\/\/\/\/\/\/|
|.\/\/..\/\/.|
|..\/....\/..|
+=*=*=*=*=*=*+
|\/\/\/\/\/\/|
|.\/\/..\/\/.|
|..\/....\/..|
|../\..../\..|
|./\/\../\/\.|
|/\/\/\/\/\/\|
+=*=*=*=*=*=*+
     /**\
    //**\\
   ///**\\\
  ////**\\\\
 /////**\\\\\

Saída para n = 3:

     /**\
    //**\\
   ///**\\\
  ////**\\\\
 /////**\\\\\
+=*=*=*=*=*=*+
|\/\/\/\/\/\/|
|.\/\/..\/\/.|
|..\/....\/..|
|../\..../\..|
|./\/\../\/\.|
|/\/\/\/\/\/\|
+=*=*=*=*=*=*+
|../\..../\..|
|./\/\../\/\.|
|/\/\/\/\/\/\|
|\/\/\/\/\/\/|
|.\/\/..\/\/.|
|..\/....\/..|
+=*=*=*=*=*=*+
|\/\/\/\/\/\/|
|.\/\/..\/\/.|
|..\/....\/..|
|../\..../\..|
|./\/\../\/\.|
|/\/\/\/\/\/\|
+=*=*=*=*=*=*+
     /**\
    //**\\
   ///**\\\
  ////**\\\\
 /////**\\\\\
absinto
fonte
3
post relacionado, do nosso inimigo: codereview.stackexchange.com/questions/65040/…

Respostas:

6

CJam, 67 63 caracteres

"дȈ鰚㒄å摒四ㄺ뎞椉ᖛⲠ줥葌⌁掗⦠춻锦䎷겲铣굛쮂먲꿡㦺좒轃汁̕뎕갴瓖邻吟㭰戔蟏㳵回㡚钦״脮烮鋉둎邫"6e4b127b:c~

Isso deve funcionar no intérprete online .

Como funciona

Depois de enviar a string Unicode, o snippet

6e4b127b:c~

converte a sequência da base 60000 para a base 127, lança na sequência e avalia o resultado.

O código que é executado é o seguinte:

"..."          " A binary string of length 42.                                            ";
122b7b         " Convert from base 122 to base 7.                                         ";
"\n *./\|"f=   " Replace each digits with the corresponding character.                    ";
60/~           " Split into chunks of length 60 and dump the resulting array.             ";
               " The stack now contains the rocket's head and a body half.                ";
[_W%[\]_W%]    " Push an array of the body half and the reversed body half, a reversed    ";
               " copy of that array and collect both array into another one.              ";
Nf*Nf+         " Join each array of body halves separating by LFs and append LFs.         ";
ri:I*           " Repeat the resulting array I := int(input()) times.                     ";
I<W%           " Keep the first I bodies and reverse their order.                         ";
\a_@\++        " Prepend and append the rocket head/tail.                                 ";
'+"=*"6*'+N+++ " Push S := '+=*=*=*=*=*=*+\n'.                                            ";
*              " Join the array of parts, separating by S.                                ";
Dennis
fonte
1
Você realmente deve contar isso em bytes, não?
Claudiu
8
@ Claudiu: E arruinar minha pontuação? : P As respostas são pontuadas por bytes de comprimento por padrão, mas a pergunta substitui isso dizendo o menor número de caracteres possível .
Dennis
10

CJam, 121 bytes

5,{_5\-S*\)_'/*"**"@'\*N}%:A['+"+
"]"=*"6**:Lri:M{M(:M;2,{M+2%:J;3,{:I'|J@2\-'.*I'.*?_J"/\\""\/"?JI)3I-?*\++_+'|N}%}%L}*A

Experimente online

Toma a entrada n via STDIN.

Vou adicionar uma explicação em algum momento mais tarde. Basicamente, é tudo apenas um monte de loops de uma maneira muito ingênua. Para alternar entre as duas partes diferentes do corpo, tenho um loop aninhado sobre a parte e um loop sobre 0e 1. Depois, basta adicionar o iterador externo e o interno e usar sua paridade para decidir entre o triângulo apontando para cima ou para baixo.

Martin Ender
fonte
Eu tenho uma java.util.NoSuchElementExceptioncópia + colar o código (apontando para Lri)
Claudiu
@ Claudiu Você inseriu um número inteiro no campo "input"?
Martin Ender
Oh sim, isso faria isso!
Claudiu
5

Ruby, 203

n,q=$*[0].to_i,"\\/"
h,r,m=1.upto(5).map{|i|(?/*i+"**"+?\\*i).center 14},?++"=*"*6+?+,3.times.map{|i|?|+?.*i+q*(3-i)+?.*(2*i)+q*(3-i)+?.*i+?|}*"\n"
p=m.reverse.tr q,"/\\"
puts h,([r,m,p,r,p,m]*n)[0,3*n],r,h

Ungolfed

Penso que, neste caso, é benéfico ter uma versão sem golfe.

n      = $*[0].to_i
head   = 1.upto(5).map { |i| ("/"*i + "**" + "\\"*i).center 14 }
ridge  = "+" + "=*"*6 + "+"
middle = 3.times.map { |i| "|" + "."*i + "\\/"*(3-i) + "."*(2*i) + "\\/"*(3-i) + "."*i + "|" }.join "\n"
piddle = middle.reverse.tr "\\/", "/\\"

puts head
puts ([ridge,middle,piddle,ridge,piddle,middle]*n)[0,3*n]
puts ridge, head

Explicação

Duvido que isso seja eficiente, mas foi divertido.

  • A entrada é retirada de ARGV.
  • hcontém a "cabeça" e a "cauda" do foguete, ros "sulcos" que separam as diferentes partes do foguete me psão as partes superior e inferior do "corpo" do foguete.
  • O corpo é construído percorrendo os elementos Array ["ridge", "top of body", "bottom of body", "ridge", "bottom of body", "top of body"]e levando os primeiros 3*nelementos.
  • puts garante que tudo tenha sua própria linha.
britishtea
fonte
3

Python, 120 + 77 + 1 = 198 caracteres

Essa acabou sendo a abordagem errada, mas eu já tinha terminado quando Martin postou sua resposta.

H,L,T,B=open("R","rb").read().decode('zip').split("X")
n=input()
for p in[H]+([B,T,L,T,B,L]*n)[:3*n][::-1]+[L,H]:print p

Requer um arquivo R(+1 para o nome do arquivo) de 77 bytes, que você pode gerar da seguinte maneira:

>>> open('R','wb').write('eJxNjMENwDAIA/+ZIm8i4Qm6Bw+PwvDFQRUFydwJwd5VMOO6ILqIRjE+LsEI4zw2fSKJ6Vzpmt4p\ndVlnRikoVWqrK+8s/X1ivozIJuo=\n'.decode('base64'))
Claudiu
fonte
3

Caracteres JS, WIP, 252b ou 173

Não é uma função, portanto, você deve definir o valor de n no início (3 aqui) e executá-lo no console ou no nodeJS.

Aqui está a versão 252b:

n=3;r=a="     /**01    //**001   ///**0001  ////**00001 /////**00000";b="1+=*=*=*=*=*=*+1";for(c=[d="|0/0/0/0/0/0/|1|.0/0/..0/0/.|1|..0/....0/..|",d.split("").reverse().join("")];n--;)r+=b+c[n%2]+1+c[1-n%2];(r+b+a).replace(/0/g,"\\").replace(/1/g,"\n")

E aqui está a versão de 173 caracteres (usando http://xem.github.io/obfuscatweet/ )

n=3;eval(unescape(escape('𬠽𨐽𘠠𘀠𘀠𛰪𚠰𜐠𘀠𘀯𛰪𚠰𜀱𘀠𘀯𛰯𚠪𜀰𜀱𘀠𛰯𛰯𚠪𜀰𜀰𜐠𛰯𛰯𛰪𚠰𜀰𜀰𘠻𨠽𘠱𚰽𚠽𚠽𚠽𚠽𚠽𚠫𜐢𞱦𫱲𚁣👛𩀽𘡼𜀯𜀯𜀯𜀯𜀯𜀯𯀱𯀮𜀯𜀯𛠮𜀯𜀯𛡼𜑼𛠮𜀯𛠮𛠮𜀯𛠮𯀢𛁤𛡳𬁬𪑴𚀢𘠩𛡲𩑶𩑲𬱥𚀩𛡪𫱩𫠨𘠢𚑝𞱮𛐭𞰩𬠫👢𚱣𦱮𙐲𧐫𜐫𨱛𜐭𫠥𜡝𞰨𬠫𨠫𨐩𛡲𩑰𫁡𨱥𚀯𜀯𩰬𘡜𧀢𚐮𬡥𬁬𨑣𩐨𛰱𛱧𛀢𧁮𘠩').replace(/uD./g,'')))
xem
fonte
Testado no console. Frio e +1, mas geralmente quando o OP solicita uma saída e não apenas um valor de retorno, é solicitada uma declaração de saída (como console.log ou alert - não sei no nodeJS).
edc65
você está certo ... eu me permiti considerar o console como uma saída. : p (também, NodeJS só pode saída no seu console afaik)
xem
3

JavaScript (E6) 252257

Uso excessivo de string.repeat

F=p=>{
  R=(n,s='.',a='')=>a+s.repeat(n)+a;
  for(i=f=o=m=n='';++i<6;)
    o+=f+R(6-i,' ')+R(i,u='/')+'**'+R(i,t='\\'),
    f='\n',
    i<4?m+=f+R(2,R(4-i,t+u,R(i-1)),'|',n+=f+R(2,R(i,u+t,R(3-i)),'|')):0;
  s=f+R(6,'=*','+'),
  console.log(o+s+R(p&1,q=m+n+s)+R(p/2,n+m+s+q)+f+o)
}
edc65
fonte
É divertido, ambos temos 252b, mas com abordagens completamente diferentes :)
xem
3

Javascript (ES3): 243 219 bytes

R=function(n){for(a='',i=5;i--;t=a+=s+'\n')for(s='**',j=6;j--;b=['|../\\..|./\\/\\.|/\\/\\/\\','|\\/\\/\\/|.\\/\\/.|..\\/..'])s=i<j?'/'+s+'\\':' '+s+' ';for(;a+='+=*=*=*=*=*=*+\n',n;)a+=(b[n&1]+b[--n&1]).replace(/[^|]+/g,'$&$&|\n');return a+t}
subzey
fonte
1: SyntaxError: function statement requires a name, 2: saída incorrecta, os segmentos corporais ahould não ser todos iguais (pares e ímpares são diferentes)
edc65
1. Isso porque se destina a ser FunctionExpression. Mas eu adicionei uma tarefa, portanto deve funcionar agora. 2. Obrigado! Eu não percebi isso no começo.
Subzey 9/10