Соленое испытание

23

Вот соленый крекер ASCII :

 _________________
|  .     .     .  |
|     .     .     |
|  .     .     .  |
|     .     .     |
|  .     .     .  |
|_________________|

Вот два сложенных крекера:

 _________________
|  .     .     .  |
|     . __________|______
|  .   |  .     .     .  |
|     .|     .     .     |
|  .   |  .     .     .  |
|______|     .     .     |
       |  .     .     .  |
       |_________________|

Напишите самую короткую возможную программу, которая принимает положительное целое число и рисует стек из множества соленых крекеров ASCII.

Входные данные могут поступать из стандартного ввода, командной строки, или вы можете просто написать функцию. Ввод всегда будет действительным. Вывод должен идти в стандартный вывод или ближайшую альтернативу.

Каждый сложенный взломщик всегда сдвигается на 2 символа вниз и на 7 символов справа от взломщика под ним. Там не должно быть никаких пробелов или посторонних символов новой строки.

Самая короткая программа в байтах побеждает.

Примеры

Если вход является 1выходом

 _________________
|  .     .     .  |
|     .     .     |
|  .     .     .  |
|     .     .     |
|  .     .     .  |
|_________________|

Если вход является 2выходом

 _________________
|  .     .     .  |
|     . __________|______
|  .   |  .     .     .  |
|     .|     .     .     |
|  .   |  .     .     .  |
|______|     .     .     |
       |  .     .     .  |
       |_________________|

Если вход является 3выходом

 _________________
|  .     .     .  |
|     . __________|______
|  .   |  .     .     .  |
|     .|     . __________|______
|  .   |  .   |  .     .     .  |
|______|     .|     .     .     |
       |  .   |  .     .     .  |
       |______|     .     .     |
              |  .     .     .  |
              |_________________|

И так далее.

настоящий солевой вызов

Кальвин Хобби
источник
1
Каким образом контур крекера ниже перекрывает контур того, что над ним?
гордый haskeller
1
@ Calvin'sHobbies: Я думаю, что он задается вопросом, почему верхняя граница сложенных крекеров ___|___вместо _______. Я предполагаю, что это было бы странно, если бы это было последнее
Клавдиу
2
@ Клаудиу Ох. Да, это не идеально, но с другой стороны выглядит страннее.
Увлечения Кэлвина
6
@ Calvin'sHobbies На самом деле, я думаю, что один персонаж - самая интересная часть этой проблемы. ^^
Мартин Эндер
3
Прохождение 0 должно быть сегфолтом.
Нафтули Кей

Ответы:

4

CJam, 140 125 119 116 байт

li__7*C+S*a\2*5+*\{5m>S'|6*+_" ."5*5/{'__@\++}:U%3*0@t{S5*U_}%\a+zsB'|tJ/{\(J>@\+a+}/{7m<}%}*{Cm<0{;)_' =}g+}%N*B'_t

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

Один солевой

Фрагмент кода

S'|6*+_      " Push ' ||||||' twice.                                                      ";
" ."5*5/     " Push [' . . ' '. . .'].                                                    ";
{'__@\++}:U% " Prepend and append an underscore to each string in the previous array.     ";
3*           " Repeat the resulting array thrice.                                         ";
0@t          " Replace its first element with ' ||||||'.                                  ";
{S5*U_}%     " Insert '_     _' after each element of the array.                          ";
\a+          " Append ' ||||||' to the array.                                             ";
z            " Zip; transpose rows with columns.                                          ";
sB'\t        " Flatten the array of strings and replace the 12th element with a '|'.      ";
19/          " Split into chunks of length 19.                                            ";

оставляет в стеке следующее:

[
  " __________|______ "
  "|  .     .     .  |"
  "|     .     .     |"
  "|  .     .     .  |"
  "|     .     .     |"
  "|  .     .     .  |"
  "|_________________|"
]

Сложенные соли

Предположим, что солевой раствор сверху сохраняется в Z.

li               " I := int(input())                                                      ";
__7*C+S*a\2*5+*  " R:= [(I * 7 + 12) * ' '] * (I * 2 + 5)                                 ";
\{               " Repeat I times:                                                        ";
  5m>            "   R := R[-5:] + R[:-5]                                                 ";
  Z              "   Push a single saltine, as an array of lines.                         ";
  {              "   For each line L of the saltine:                                      ";
    \(J>@\+a+    "     R := R[1:] + [R[0][19:] +     L]                                   ";
  }/             "                                                                        ";
  {7m<}%         "   R := [ L[7:] + L[:7] : L in R ]                                      ";
}*               "                                                                        ";
{                " R := [                                                                 ";
  Cm<            "   (L[12:] + L[:12])                                                    ";
  0{;)_' =}g+    "                    .rstrip()                                           ";
}%               " : L in R ]                                                             ";
N*               " R := '\n'.join(R)                                                      ";
B'_t             " R[11] := '|'                                                           ";
Деннис
источник
11

JavaScript (E6) 249 259 289 304 345

Не очень уверен насчет сжатия строк. Нашел хорошее сжатие для струн. Простой случай с 1 взломщиком кажется сложным в управлении. Там может быть лучший способ ...

F=n=>{
  for(B=",|4.,|1.2,|1.4.4.1|,|5,|4.4.4|, 9|5, 87 ,|87|".replace(/\d/g,c=>' _'[c>4|0][R='repeat'](-~c)).split(','),
  O=(c,b=0,a=0)=>console.log(' '[R](y)+B[a]+B[b][R](x)+B[c]),
  r=x=y=0,
  O(7);
  O(3,2),
  !(z=++r>2)|x;)
    x+=(v=r<n)-z,O(v+5,1,z*4),y+=z*7;
  O(8)
}

Неуправляемый более или менее

Это основной код, прежде чем я начал играть в гольф. Это не совсем то же самое и работает только для n> 2

F=n=>{
  O=t=>console.log(t)

  r=0
  x=0
  y=0

  O(' _________________')
  O(' '.repeat(y)+'|  .   '.repeat(x)+'|  .     .     .  |')

  while (++r<n)
  {
    x++;
    if (r>2)
    {
       x--;
       O(' '.repeat(y)+'|______'+'|     .'.repeat(x)+' __________|______')
       y+=7;
       O(' '.repeat(y)+'|  .   '.repeat(x)+'|     .     .     |')
    }
    else
    {
       O(' '.repeat(y)+'|     .'.repeat(x)+' __________|______')
       O(' '.repeat(y)+'|  .   '.repeat(x)+'|  .     .     .  |')
    }

  }  
  while(x--)
  {
     O(' '.repeat(y)+'|______'+'|     .'.repeat(x)+'|  .     .     .  |')
     y+=7;
     O(' '.repeat(y)+'|  .   '.repeat(x)+'|     .     .     |')
  }

  O(' '.repeat(y)+'|_________________|')
}

Тест в консоли FireFox / FireBug

F(4)

Выход

 _________________
|  .     .     .  |
|     . __________|______
|  .   |  .     .     .  |
|     .|     . __________|______
|  .   |  .   |  .     .     .  |
|______|     .|     . __________|______
       |  .   |  .   |  .     .     .  |
       |______|     .|     .     .     |
              |  .   |  .     .     .  |
              |______|     .     .     |
                     |  .     .     .  |
                     |_________________|
edc65
источник
8

Python, 252 241 символов

s="eJxTiIeDGgiloBBRo6CgpwACcLIGJKaAKlxDmbp4dFADAL+oIFI=".decode('base64').decode('zip').split('X')
N=input()
R=range
G=map(list,[' '*(7*N+12)]*(2*N+5))
for n in R(N):
 for y in R(7):G[2*n+y][7*n:]=s[y]
G[0][11]='_'
for g in G:print''.join(g)

Спасибо FryAmTheEggman и Винсенту за то, что они украли 11 персонажей.

Преобладание крекеров:

$ echo 17 | python saltines.py
 _________________
|  .     .     .  |
|     . __________|______
|  .   |  .     .     .  |
|     .|     . __________|______
|  .   |  .   |  .     .     .  |
|______|     .|     . __________|______
       |  .   |  .   |  .     .     .  |
       |______|     .|     . __________|______
              |  .   |  .   |  .     .     .  |
              |______|     .|     . __________|______
                     |  .   |  .   |  .     .     .  |
                     |______|     .|     . __________|______
                            |  .   |  .   |  .     .     .  |
                            |______|     .|     . __________|______
                                   |  .   |  .   |  .     .     .  |
                                   |______|     .|     . __________|______
                                          |  .   |  .   |  .     .     .  |
                                          |______|     .|     . __________|______
                                                 |  .   |  .   |  .     .     .  |
                                                 |______|     .|     . __________|______
                                                        |  .   |  .   |  .     .     .  |
                                                        |______|     .|     . __________|______
                                                               |  .   |  .   |  .     .     .  |
                                                               |______|     .|     . __________|______
                                                                      |  .   |  .   |  .     .     .  |
                                                                      |______|     .|     . __________|______
                                                                             |  .   |  .   |  .     .     .  |
                                                                             |______|     .|     . __________|______
                                                                                    |  .   |  .   |  .     .     .  |
                                                                                    |______|     .|     . __________|______
                                                                                           |  .   |  .   |  .     .     .  |
                                                                                           |______|     .|     . __________|______
                                                                                                  |  .   |  .   |  .     .     .  |
                                                                                                  |______|     .|     .     .     |
                                                                                                         |  .   |  .     .     .  |
                                                                                                         |______|     .     .     |
                                                                                                                |  .     .     .  |
                                                                                                                |_________________|

Этот код кажется действительно неэффективным, но другие ответы скажут. Он просто копирует и вставляет солевой взломщик в массив в нужном месте, считая, что самый нижний взломщик отключен на 1 символ, а затем печатает все это.

Я могу уменьшить его до 230 символов, если использую внешний файл (202 кода + 38 размера файла + 1 имя файла).

Клаудиу
источник
11
Пожалуйста, покажите все выходные данные, n=1 upto 2^10чтобы мы могли быть уверены, что ваша программа действительно работает правильно.
flawr
list(' '*(7*N+12))может быть [' ']*(7*N+12).
FryAmTheEggman
1
@Flawr: Сэр, это значит - вы говорите - вы, ах, намекаете - намекать или, возможно, просто предполагаете, что я был глуп?
Клаудиу
1
@Claudiu Я могу заверить, что я бы даже не осмелился подумать о том, чтобы вдохновить вас на действие, которое могло бы иметь лишь непреложное прикосновение глупостей. = P
flawr
1
И G=[list(' '*(7*N+12))for _ in R(2*N+5)]сG=map(list,[' '*(7*N+12)]*(2*N+5))
Винсент
7

Perl 189

Похищая некоторые идеи сжатия строк у Чороба, я понял:

echo 4 | perl -E 's/\d/($&<8?$":_)x$&/ge for@l=("|2.5.5.2|"," 98","|5.5.5|","|98|",7)[102020344=~/./g];map{say for@l[0,1];$l[$_]=substr($l[$_+2],0,7).$l[$_]for 0..6;substr$l[0],-7,1,"|"}2..<>;say for@l[0..6]'

Для более удобного просмотра в вашем браузере:

s/\d/($&<8?$":_)x$&/ge for@l=
("|2.5.5.2|"," 98","|5.5.5|","|98|",7)[102020344=~/./g];map{
    say for@l[0,1];
    $l[$_]=substr($l[$_+2],0,7).$l[$_]for 0..6;
    substr$l[0],-7,1,"|"
}2..<>;say for@l[0..6]

Для контекста, мой лучший до этого:

Perl 207

$u='_'x11;s/:/ .  /g,s/.(.)/$&$1/g,$_.=$/for@l=("|:: . |"," $u","|  :: |","|$u|",$"x5)[102020344=~/./g];map{print@l[0,1];$l[$_]=substr($l[$_+2],0,7).$l[$_]for 0..6;substr$l[0],-8,1,'|'}2..pop;print@l[0..6]

Добавление новых строк и отступов для удобства чтения в вашем браузере:

$u="_"x11;
s/:/ .  /g,s/.(.)/$&$1/g,$_.=$/for@l=
("|:: . |"," $u","|  :: |","|$u|",$"x5)[102020344=~/./g];
map{
    print@l[0,1];
    $l[$_]=substr($l[$_+2],0,7).$l[$_]for 0..6;
    substr$l[0],-8,1,"|"
}2..pop;
print@l[0..6]

Вы можете заменить «pop» на «<>», чтобы считать счетчик из STDIN вместо параметра командной строки и получить 206 байт. Переход к STDERR уменьшит его до 204 байтов.

Если бы я мог включить функцию «сказать» без байтового штрафа, то я мог бы получить 202.

$u="_"x11;s/:/ .  /g,s/.(.)/$&$1/g for@l=("|:: . |"," $u","|  :: |","|$u|",$"x5)[102020344=~/./g];map{say for@l[0,1];$l[$_]=substr($l[$_+2],0,7).$l[$_]for 0..6;substr$l[0],-7,1,"|"}2..<>;say for@l[0..6]

вызывается как:

echo 4 | perl -E '$u="_"x11;s/:/ .  /g,s/.(.)/$&$1/g for@l=("|:: . |"," $u","|  :: |","|$u|",$"x5)[102020344=~/./g];map{say for@l[0,1];$l[$_]=substr($l[$_+2],0,7).$l[$_]for 0..6;substr$l[0],-7,1,"|"}2..<>;say for@l[0..6]'
Тая
источник
Вы можете включить sayбез штрафа, потому что это то же самое, что запуск в командной строке с -Eвместо -e. perl -E''не учитывается в общем количестве ваших персонажей.
hmatt1
Ваш вывод неверен. Проверьте _|_.
Чороба
@choroba, спасибо! Я забыл вернуть этот substr после попытки заменить его на y / | / _ / (но всегда заканчивался более длинным кодом). С 168 до 189.
Тай
4

Perl 201

(удалить символы новой строки, кроме первой, чтобы получить #)

$_=" 46|6
15.5.5|15.5.5|198|";
s/1/|  .5.5.  ||/g;
s/\d/(5^$&?_:$")x$&/ge;
@o=@l=/.{18}.?/g;
map{
$s=$_*7;
substr$o[$_-5],$s,12,$l[$_]for 0..4;
push@o,($"x$s).$l[$_]for 5,6
}1..-1+pop;
$o[$,=$/]=~y/|/_/;
print@o

say+ <>= 198.

choroba
источник
«Там не должно быть висячих пробелов»
Tye
@Tye: ОК, вернемся к 202 :-(
Чороба
2

Haskell, 215 байт

Этот пример создает стек взломщика индуктивно, вытягивая части взломщика и делая интервалы из пары циклических списков:

(b:u:i)=" _|"
(%)=replicate
z=5%b++'.':z
m!n=i++map(z!!)[m..n]
s=7%b:s
d=3!19++i
e=0!16++i
y=i++6%u
g 1=[e,d,e,d,i++17%u++i]
g k=zipWith(++)(0!5:3!8:0!5:3!8:y:s)$(b:10%u++y):d:g(k-1)
f k=mapM putStrLn$(b:17%u):d:g k

Поток управления довольно прост; большая часть хитрости заключается в повторном использовании как можно большего количества частей взломщика.

Ungolfed:

top     = " _________________"
top'    = " __________|______"
dots3   = "|  .     .     .  |"
dots2   = "|     .     .     |"
bot     = "|_________________|"

halfR   = "|     ."
halfL   = "|  .   "
halfBot = "|______"

spacer  = "       "
spaces = repeat spacer

saltine = above ++ [dots2, dots3, dots2, dots3, bot]
above   = [top, dots3]
left    = [halfR, halfL, halfR, halfL, halfBot] ++ spaces

another (oldTop:oldCracker) = above ++ zipWith (++) left (top' : oldCracker)

crackers 1 = saltine
crackers k = another $ crackers (k - 1)

test = putStr . unlines . crackers
Мэтт Нунан
источник
1

Питон, 299

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

N=input()
m,n,c,r=12+7*N,5+2*N,3.5,range
print''.join(i>m-2and'\n'or(i%7<(i/c<j<7+i/c)*(i<N*7)or(i+4)%7<(i/c<j+4<2+4*(i>m-3)+i/c)*(i>16))and'|'or j%2<(j*c<i<17+j*c)*(j<n-5)+(j*c<i+22<8+10*(j>n-3)+j*c)*(j>5)and'_'or(i-j*3-min(i/7,~-j/2,N-1)+1)%6<(-3<-~i/7-j/2<3)and'.'or' 'for j in r(n)for i in r(m))

И последняя строка расширилась, чтобы увидеть, что происходит:

print ''.join(
              '\n' if i>m-2 else
              '|' if i%7<(i/c<j<7+i/c)*(i<N*7) or (i+4)%7<(i/c<j+4<2+4*(i>m-3)+i/c)*(i>16) else
              '_' if j%2<(j*c<i<17+j*c)*(j<n-5)+(j*c<i+22<8+10*(j>n-3)+j*c)*(j>5) else
              '.' if (i-j*3-min(i/7,~-j/2,N-1)+1)%6<(-3<-~i/7-j/2<3) else
              ' '
              for j in r(n)
              for i in r(m)
             )
Эмиль
источник
1

С, 284

Для функции fи #defineс, исключая ненужные пробелы и main. В соответствии с комментарием edc65, я включил 128-битный целочисленный тип (который я собирался сделать в любом случае), но я снова просчитался и могу сделать только 29 взломщиков, прежде чем вершины начнут пропадать.

Завершите функцию и программу тестирования ниже. Прокомментирую это позже.

#define C b,b,c,b,b
#define S s[i/v*7-i%v
f(n){
  __int128 a=4095,b=a+2,c=6281,d=4641,w=998,v=19,s[998]={a,C,d,C,d,C,a},i=v;
  for(;i<n*v;i++)S+18]|=S+11]*16&-1<<(12+i/v*2-i%v/18)*(i%v>7); 
  for(i=(5+n*2)*w;i--;i%w||puts(""))i%w>i/w/2*7-21+i/w%2*6&&s[i%w]&&putchar(" _.|"[(s[i%w]>>i/w*2)&3]);
}


main(){
  int m;
  scanf("%d",&m);f(m);
}

В выводе только четыре разных символа. Они декодируются из двоичных чисел 0-3 " _.|". Массив s[]содержит целое число для каждого столбца выходных данных, 2 бита на символ, который инициализируется для того, чтобы содержать самый правый взломщик.

Первый forцикл копирует предыдущий взломщик, сдвигает его, чтобы переместить вверх, удаляет нижний правый угол с помощью &и ИЛИ с предыдущим взломщиком, на 7 шагов влево.

Второй forцикл декодирует 2-битное представление каждого символа в фактический символ и печатает символ. Здесь много кода, чтобы просто исключить ненужные пробелы в выводе. Я разочарован тем, что мой счет вырос, а не снизился по сравнению с моей предыдущей ревизией.

Выход

Это 29 взломщиков. Я заменил пробел -на другой, чтобы показать, что в выводе нет пробелов или посторонних символов новой строки.

-_________________
|--.-----.-----.--|
|-----.-__________|______
|--.---|--.-----.-----.--|
|-----.|-----.-__________|______
|--.---|--.---|--.-----.-----.--|
|______|-----.|-----.-__________|______
-------|--.---|--.---|--.-----.-----.--|
-------|______|-----.|-----.-__________|______
--------------|--.---|--.---|--.-----.-----.--|
--------------|______|-----.|-----.-__________|______
---------------------|--.---|--.---|--.-----.-----.--|
---------------------|______|-----.|-----.-__________|______
----------------------------|--.---|--.---|--.-----.-----.--|
----------------------------|______|-----.|-----.-__________|______
-----------------------------------|--.---|--.---|--.-----.-----.--|
-----------------------------------|______|-----.|-----.-__________|______
------------------------------------------|--.---|--.---|--.-----.-----.--|
------------------------------------------|______|-----.|-----.-__________|______
-------------------------------------------------|--.---|--.---|--.-----.-----.--|
-------------------------------------------------|______|-----.|-----.-__________|______
--------------------------------------------------------|--.---|--.---|--.-----.-----.--|
--------------------------------------------------------|______|-----.|-----.-__________|______
---------------------------------------------------------------|--.---|--.---|--.-----.-----.--|
---------------------------------------------------------------|______|-----.|-----.-__________|______
----------------------------------------------------------------------|--.---|--.---|--.-----.-----.--|
----------------------------------------------------------------------|______|-----.|-----.-__________|______
-----------------------------------------------------------------------------|--.---|--.---|--.-----.-----.--|
-----------------------------------------------------------------------------|______|-----.|-----.-__________|______
------------------------------------------------------------------------------------|--.---|--.---|--.-----.-----.--|
------------------------------------------------------------------------------------|______|-----.|-----.-__________|______
-------------------------------------------------------------------------------------------|--.---|--.---|--.-----.-----.--|
-------------------------------------------------------------------------------------------|______|-----.|-----.-__________|______
--------------------------------------------------------------------------------------------------|--.---|--.---|--.-----.-----.--|
--------------------------------------------------------------------------------------------------|______|-----.|-----.-__________|______
---------------------------------------------------------------------------------------------------------|--.---|--.---|--.-----.-----.--|
---------------------------------------------------------------------------------------------------------|______|-----.|-----.-__________|______
----------------------------------------------------------------------------------------------------------------|--.---|--.---|--.-----.-----.--|
----------------------------------------------------------------------------------------------------------------|______|-----.|-----.-__________|______
-----------------------------------------------------------------------------------------------------------------------|--.---|--.---|--.-----.-----.--|
-----------------------------------------------------------------------------------------------------------------------|______|-----.|-----.-__________|______
------------------------------------------------------------------------------------------------------------------------------|--.---|--.---|--.-----.-----.--|
------------------------------------------------------------------------------------------------------------------------------|______|-----.|-----.-__________|______
-------------------------------------------------------------------------------------------------------------------------------------|--.---|--.---|--.-----.-----.--|
-------------------------------------------------------------------------------------------------------------------------------------|______|-----.|-----.-__________|______
--------------------------------------------------------------------------------------------------------------------------------------------|--.---|--.---|--.-----.-----.--|
--------------------------------------------------------------------------------------------------------------------------------------------|______|-----.|-----.-__________|______
---------------------------------------------------------------------------------------------------------------------------------------------------|--.---|--.---|--.-----.-----.--|
---------------------------------------------------------------------------------------------------------------------------------------------------|______|-----.|-----.-__________|______
----------------------------------------------------------------------------------------------------------------------------------------------------------|--.---|--.---|--.-----.-----.--|
----------------------------------------------------------------------------------------------------------------------------------------------------------|______|-----.|-----.-__________|______
-----------------------------------------------------------------------------------------------------------------------------------------------------------------|--.---|--.---|--.-----.-----.--|
-----------------------------------------------------------------------------------------------------------------------------------------------------------------|______|-----.|-----.-__________|______
------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--.---|--.---|--.-----.-----.--|
------------------------------------------------------------------------------------------------------------------------------------------------------------------------|______|-----.|-----.-__________|______
-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--.---|--.---|--.-----.-----.--|
-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|______|-----.|-----.-__________|______
--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--.---|--.---|--.-----.-----.--|
--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|______|-----.|-----.-----.-----|
---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--.---|--.-----.-----.--|
---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|______|-----.-----.-----|
----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--.-----.-----.--|
----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|_________________|
Уровень реки St
источник
В вопросе не было максимального значения, только «положительное целое число». Итак, с 1 по 5 - ваша идея о каком-либо натуральном числе?
edc65 10.10.14
@ edc65 Для еще нескольких байтов вы можете иметь 128-битный целочисленный тип вместо 32-битного. Для этого потребуется до 56 взломщиков, чего должно быть достаточно (это более 20 КБ на выходе). Я признаю, что просчитал количество взломщиков, которое я мог получить с 32-битным целым числом, когда я начал, я думал, что это было по крайней мере десять. Но да, у всех программ будет какой-то верхний предел количества взломщиков, которые они могут производить, и ОП должен решить, что это такое. Это должно быть указано в вопросе. Так как это, я приму постановление ФП о достоверности моего ответа (который еще не закончен)
Level River St
0

JavaScript (ES6) HTML5 - 233 236 байт

Вероятно, не правильный ответ, но я просто не мог удержаться от публикации, извините :-P

F=n=>{d="______";b="\n|  .     .     .  |";a=b+"\n|     .     .     |";for(i=0;i<n;)document.body.innerHTML+="<pre style='background:#fff;position:fixed;top:"+i*28+"px;left:"+i*56+"px'> ____"+d+'|_'[+!i++]+d+a+a+b+"\n|"+d+d+"_____|"}

Тест в Firefox с F(1), F(2), F(3)и т.д.

Пример: http://jsfiddle.net/Lvmg9fe8/7/

я и мой кот
источник
Я не знаю JavaScript, но эта Fiddle, похоже, ничего не делает (тогда как я смог запустить другие Fiddles без проблем). У меня есть Google Chrome и Internet Explorer.
Уровень Река St
@steveverrill работает только в Firefox, как и почти все, что продается здесь как JavaScript. Chrome и IE не поддерживают EcmaScript 6.
я и мой кот
Это работает (в Firefox), хотя это не совсем то, что я ищу;)
Увлечения Кэлвина
Кажется, я тоже не могу заставить это работать ... Я получаю "неопределенный" ответ всякий раз, когда я вхожу, F(1)или любое другое число, после того, как я ввел этот код в консоль JS в Firefox ...
WallyWest