Роздрукуйте Ретро Ракету


13

(натхненний цим питанням SO )

Вам вводиться як вхід єдине натуральне число n .

Якнайменше символів виведіть ракету в мистецтві ASCII з головою, хвостом і тілом, складеними з n сегментів. Не повинно бути пробілів чи нових рядків.

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

Вихід для n = 1:

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

Вихід для n = 2:

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

Вихід для n = 3:

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

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 Чи ввели ви ціле число в полі "введення"?
Мартін Ендер

О так, це зробить!
Клавдіу

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

Безумовно

Я думаю, що в цьому випадку вигідно мати версію, яка не використовується для гольфу.

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 гарантує, що все набуває своєї лінії.

3

Пітон, 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,'')))

Тестується в консолі. Cool та +1, але зазвичай, коли ОП запитує вихід, а не просто повернене значення, запитується вихідний оператор (наприклад, console.log або попередження - я не знаю в 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)
}

це весело, у нас обох 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}

1:, SyntaxError: function statement requires a name2: неправильний вихід, сегменти тіла не повинні бути всіма рівними (непарні і парні)
edc65

1. Це тому, що він призначений для FunctionExpression. Але я додав завдання, тому воно має працювати зараз. 2. Дякую! Я спочатку цього не помічав.
subzey
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.