Распечатать Ретро Ракета

13

(вдохновленный этим ТАКИМ вопросом )

Вам дают в качестве входных данных одно положительное целое число n .

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

Голова и хвост ракеты всегда одинаковы для любого значения n . Тело состоит из двух различных типов сегментов, которые чередуются. Примеры должны прояснить структуру ракеты.

Выход для n = 1:

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

Выход для n = 2:

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

Выход для n = 3:

     /**\
    //**\\
   ///**\\\
  ////**\\\\
 /////**\\\\\
+=*=*=*=*=*=*+
|\/\/\/\/\/\/|
|.\/\/..\/\/.|
|..\/....\/..|
|../\..../\..|
|./\/\../\/\.|
|/\/\/\/\/\/\|
+=*=*=*=*=*=*+
|../\..../\..|
|./\/\../\/\.|
|/\/\/\/\/\/\|
|\/\/\/\/\/\/|
|.\/\/..\/\/.|
|..\/....\/..|
+=*=*=*=*=*=*+
|\/\/\/\/\/\/|
|.\/\/..\/\/.|
|..\/....\/..|
|../\..../\..|
|./\/\../\/\.|
|/\/\/\/\/\/\|
+=*=*=*=*=*=*+
     /**\
    //**\\
   ///**\\\
  ////**\\\\
 /////**\\\\\
абсент
источник

Ответы:

6

CJam, 67 63 символа

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

Это должно работать в онлайн-переводчике .

Как это устроено

После нажатия строки Unicode, фрагмент

6e4b127b:c~

преобразует строку из базы 60000 в базу 127, преобразует в строку и оценивает результат.

Выполненный код выглядит следующим образом:

"..."          " 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
Вы должны действительно посчитать это в байтах, не так ли?
Клавдиу
8
@Claudiu: И испортишь мой счет? : P Ответы оцениваются по длине в байтах по умолчанию, но вопрос отменяет это, говоря как можно меньше символов .
Деннис
10

CJam, 121 байт

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

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

Принимает ввод n через STDIN.

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

Мартин Эндер
источник
Я получил java.util.NoSuchElementExceptionкопию + вставил код (указывая на Lri)
Claudiu
@Claudiu Вы ввели целое число в поле ввода?
Мартин Эндер
Ах, да, это сделало бы это!
Клаудиу
5

Рубин, 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

Я думаю, что в этом случае выгодно иметь версию без гольфа.

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

объяснение

Я сомневаюсь, что это где-то близко к эффективности, но, тем не менее, это было весело.

  • Вклад взят из ARGV.
  • hсодержит «голову» и «хвост» ракеты, rсодержит «гребни», которые разделяют различные части ракеты mи pявляются верхней и нижней частями «корпуса» ракеты.
  • Тело строится на велосипеде по Array ["ridge", "top of body", "bottom of body", "ridge", "bottom of body", "top of body"]первым 3*nэлементам.
  • puts удостоверяется, что все получает свою собственную линию.
britishtea
источник
3

Python, 120 + 77 + 1 = 198 символов

Это оказалось неправильным подходом, но я уже закончил, когда Мартин опубликовал свой ответ.

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

Требуется файл R(+1 для имени файла) размером 77 байт, который вы можете сгенерировать следующим образом:

>>> open('R','wb').write('eJxNjMENwDAIA/+ZIm8i4Qm6Bw+PwvDFQRUFydwJwd5VMOO6ILqIRjE+LsEI4zw2fSKJ6Vzpmt4p\ndVlnRikoVWqrK+8s/X1ivozIJuo=\n'.decode('base64'))
Клаудиу
источник
3

JS, WIP, 252b или 173 символа

Это не функция, поэтому вы должны установить значение n в начале (3 здесь), а затем выполнить его в консоли или в nodeJS.

Вот версия 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")

А вот версия с 173 символами (используется http://xem.github.io/obfuscatweet/ )

n=3;eval(unescape(escape('𬠽𨐽𘠠𘀠𘀠𛰪𚠰𜐠𘀠𘀯𛰪𚠰𜀱𘀠𘀯𛰯𚠪𜀰𜀱𘀠𛰯𛰯𚠪𜀰𜀰𜐠𛰯𛰯𛰪𚠰𜀰𜀰𘠻𨠽𘠱𚰽𚠽𚠽𚠽𚠽𚠽𚠫𜐢𞱦𫱲𚁣👛𩀽𘡼𜀯𜀯𜀯𜀯𜀯𜀯𯀱𯀮𜀯𜀯𛠮𜀯𜀯𛡼𜑼𛠮𜀯𛠮𛠮𜀯𛠮𯀢𛁤𛡳𬁬𪑴𚀢𘠩𛡲𩑶𩑲𬱥𚀩𛡪𫱩𫠨𘠢𚑝𞱮𛐭𞰩𬠫👢𚱣𦱮𙐲𧐫𜐫𨱛𜐭𫠥𜡝𞰨𬠫𨠫𨐩𛡲𩑰𫁡𨱥𚀯𜀯𩰬𘡜𧀢𚐮𬡥𬁬𨑣𩐨𛰱𛱧𛀢𧁮𘠩').replace(/uD./g,'')))
XEM
источник
Проверено в консоли. Классно и +1, но обычно, когда OP запрашивает вывод, а не просто возвращаемое значение, запрашивается оператор вывода (например, console.log или alert - я не знаю в nodeJS).
edc65
Вы правы ... Я позволил себе считать консоль выводом. : p (также, nodeJS может выводить только на свою консоль afaik)
xem
3

JavaScript (E6) 252 257

Чрезмерное использование 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
источник
это весело, у нас обоих 252b, но с совершенно разными подходами :)
xem
3

Javascript (ES3): 243 219 байт

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
источник
1:, SyntaxError: function statement requires a name2: неверный вывод, сегменты тела не должны быть одинаковыми (нечетные и четные)
edc65
1. Это потому, что он предназначен для FunctionExpression. Но я добавил назначение, поэтому оно должно работать сейчас. 2. Спасибо! Сначала я этого не заметил.
subzey