Stampa il razzo retrò


13

(ispirato a questa domanda SO )

Ti viene dato come input un singolo intero positivo n .

Nel minor numero di personaggi possibile, genera un razzo in arte ASCII con una testa, una coda e un corpo composto da n segmenti. Non dovrebbero esserci spazi finali o newline.

La testa e la coda del razzo sono sempre le stesse per qualsiasi valore di n . Il corpo è costituito da due diversi tipi di segmenti che si alternano. Gli esempi dovrebbero chiarire la struttura del razzo.

Uscita per n = 1:

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

Uscita per n = 2:

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

Uscita per n = 3:

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

3
post correlato, dalla nostra nemesi: codereview.stackexchange.com/questions/65040/…

Risposte:


6

CJam, 67 63 caratteri

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

Questo dovrebbe funzionare nell'interprete online .

Come funziona

Dopo aver premuto la stringa Unicode, lo snippet

6e4b127b:c~

converte la stringa dalla base 60000 alla base 127, esegue il cast alla stringa e valuta il risultato.

Il codice che viene eseguito è il seguente:

"..."          " 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.                                ";

1
Dovresti davvero contare questo in byte, no?
Claudiu,

8
@Claudiu: E rovinare il mio punteggio? : P Le risposte sono classificate in base ai loro byte di lunghezza per impostazione predefinita, ma la domanda ha la precedenza su questo dicendo il minor numero possibile di caratteri .
Dennis,

10

CJam, 121 byte

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

Provalo online

Accetta l'ingresso n tramite STDIN.

Aggiungerò una spiegazione ad un certo punto più tardi. Fondamentalmente è tutto solo un mucchio di anelli in un modo molto ingenuo. Per alternare tra le due diverse parti del corpo, ho un loop nidificato sulla parte e un loop su 0e 1. Quindi aggiungo solo l'iteratore esterno e quello interno e uso la loro parità per decidere tra il triangolo rivolto verso l'alto o verso il basso.


Ho avuto una java.util.NoSuchElementExceptioncopia + incollando il codice (indicando Lri)
Claudiu,

@Claudiu Hai inserito un numero intero nel campo "input"?
Martin Ender,

Oh sì, lo farebbe!
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 che in questo caso sia utile avere una versione non giocata a golf.

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

Spiegazione

Dubito che questo sia quasi efficiente, ma è stato comunque divertente.

  • L'input è preso da ARGV.
  • hcontiene la "testa" e la "coda" del razzo, rcontiene le "creste" che separano le diverse parti del razzo me psono le parti superiore e inferiore del "corpo" del razzo.
  • Il corpo è costruito pedalando attraverso Array ["ridge", "top of body", "bottom of body", "ridge", "bottom of body", "top of body"]e prendendo i primi 3*nelementi.
  • puts si assicura che tutto ottenga la propria linea.

3

Python, 120 + 77 + 1 = 198 caratteri

Questo ha finito per essere l'approccio sbagliato, ma avevo già finito quando Martin ha pubblicato la sua risposta.

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

Richiede un file R(+1 per il nome file) di 77 byte, che è possibile generare come segue:

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

3

JS, WIP, 252b o 173 caratteri

Non è una funzione, quindi devi impostare il valore di n all'inizio (3 qui), quindi eseguirlo nella console o in nodeJS.

Ecco la versione 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")

Ed ecco la versione 173 caratteri (usando http://xem.github.io/obfuscatweet/ )

n=3;eval(unescape(escape('𬠽𨐽𘠠𘀠𘀠𛰪𚠰𜐠𘀠𘀯𛰪𚠰𜀱𘀠𘀯𛰯𚠪𜀰𜀱𘀠𛰯𛰯𚠪𜀰𜀰𜐠𛰯𛰯𛰪𚠰𜀰𜀰𘠻𨠽𘠱𚰽𚠽𚠽𚠽𚠽𚠽𚠫𜐢𞱦𫱲𚁣👛𩀽𘡼𜀯𜀯𜀯𜀯𜀯𜀯𯀱𯀮𜀯𜀯𛠮𜀯𜀯𛡼𜑼𛠮𜀯𛠮𛠮𜀯𛠮𯀢𛁤𛡳𬁬𪑴𚀢𘠩𛡲𩑶𩑲𬱥𚀩𛡪𫱩𫠨𘠢𚑝𞱮𛐭𞰩𬠫👢𚱣𦱮𙐲𧐫𜐫𨱛𜐭𫠥𜡝𞰨𬠫𨠫𨐩𛡲𩑰𫁡𨱥𚀯𜀯𩰬𘡜𧀢𚐮𬡥𬁬𨑣𩐨𛰱𛱧𛀢𧁮𘠩').replace(/uD./g,'')))

Testato in console. Cool e +1, ma di solito quando l'OP richiede un output e non solo un valore di ritorno, viene richiesta un'istruzione output (come console.log o alert - non lo so in nodeJS).
edc65,

hai ragione ... Mi sono permesso di considerare la console come un output. : p (inoltre, nodeJS può essere riprodotto solo sulla sua console
afaik

3

JavaScript (E6) 252257

Uso eccessivo di 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)
}

è divertente, entrambi abbiamo 252b ma con approcci completamente diversi :)
xem

3

Javascript (ES3): 243 219 byte

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}

1 SyntaxError: function statement requires a name:, 2: uscita errata, i segmenti del corpo non dovrebbero essere tutti uguali (pari e dispari sono diversi)
edc65

1. Questo perché è destinato a essere FunctionExpression. Ma ho aggiunto un compito, quindi dovrebbe funzionare ora. 2. Grazie! All'inizio non me ne accorsi.
subzey
Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.