Выведите легендарный Иггдрасиль


39

Ваша задача - вывести изображение легендарного древа жизни Иггдрасиля .

Вы должны написать программу, вывод которой именно такой:

                                       /\
                                      /**\
                                     /****\
                                    /******\
                                    /******\
                                   /********\
                                  /**********\
                                 /************\
                                /**************\
                                 /************\
                                /**************\
                               /****************\
                              /******************\
                             /********************\
                            /**********************\
                              /******************\
                             /********************\
                            /**********************\
                           /************************\
                          /**************************\
                         /****************************\
                        /******************************\
                           /************************\
                          /**************************\
                         /****************************\
                        /******************************\
                       /********************************\
                      /**********************************\
                     /************************************\
                    /**************************************\
                        /******************************\
                       /********************************\
                      /**********************************\
                     /************************************\
                    /**************************************\
                   /****************************************\
                  /******************************************\
                 /********************************************\
                /**********************************************\
                     /************************************\
                    /**************************************\
                   /****************************************\
                  /******************************************\
                 /********************************************\
                /**********************************************\
               /************************************************\
              /**************************************************\
             /****************************************************\
            /******************************************************\
                  /******************************************\
                 /********************************************\
                /**********************************************\
               /************************************************\
              /**************************************************\
             /****************************************************\
            /******************************************************\
           /********************************************************\
          /**********************************************************\
         /************************************************************\
        /**************************************************************\
               /************************************************\
              /**************************************************\
             /****************************************************\
            /******************************************************\
           /********************************************************\
          /**********************************************************\
         /************************************************************\
        /**************************************************************\
       /****************************************************************\
      /******************************************************************\
     /********************************************************************\
    /**********************************************************************\
            /******************************************************\
           /********************************************************\
          /**********************************************************\
         /************************************************************\
        /**************************************************************\
       /****************************************************************\
      /******************************************************************\
     /********************************************************************\
    /**********************************************************************\
   /************************************************************************\
  /**************************************************************************\
 /****************************************************************************\
/******************************************************************************\
                                   |--------|
                                   |--------|
                                   |--------|
                                   |--------|
                                   |--------|
                                   |--------|
                                   |--------|
                                   |--------|
                                   |--------|
                                   |--------|
                                   |--------|
                                   |________|

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

Чтобы упростить проверку, вот суммы md5 ожидаемого результата:

  • 374899e56bc854d04639c43120642e37 - Нет новой строки в конце.
  • 03afb81d960b8e130fe2f9e0906f0482 - Новая строка в конце

Применяются стандартные лазейки. Это код-гольф, поэтому выигрывает самая маленькая запись в байтах!


10
Связанный: codegolf.stackexchange.com/q/15860/15599 . Накс, ты должен работать в маркетинге. Каждое семейство будет хотеть Иггдрасиль в это Рождество. Я вижу, вы тоже ответили на вопрос о числе Грэм. Вы должны любить острые вещи. Давайте добавим несколько новых имен для «ракета» и «мороженое».
Уровень Река St


4
@Nax: поскольку у мирового дерева есть плоды, а у покрытосеменных нет, и это явно ограничивает некоторые описания, к сожалению, похоже, что вы сфотографировали неправильное дерево: P
naught101

@Nax Хм. Ты прав. Педант (я) поднимается на собственной петарде. Суммы md5 изменились.
Скотт Лидли

1
Э-э-э, порядок, Иггдрасиль - это определенно ясень в Эддах, а не пихта. Вроде как .
Алекс П

Ответы:


22

Golfscript, 84 77 76 75 72 персонажа

Отличный подход от Говарда . Нажмите на количество символов, чтобы попробовать это.

10,{.)4*,\3*>{.39\-' '*'/'@2*'*'*'\
'}/}/12,{' '35*'|'@11<'_-'1/=8*1$n}/

Спасибо Говарду за сохранение 3 символов!

Пояснение :

Это более или менее простой порт моего решения на Python . Взяв некоторые выразительные свободы (используя именованные переменные вместо отслеживания позиций стека, и printдействительно хранит вещи в стеке, а не печатает):

10,{...}/            # for i in range(10):
   .                 #    x = i
   )4*,              #    Y = range((i+1)*4)
   \3*               #    x *= 3
   >                 #    Y = Y[x:]  # y is now range(3*i, (i+1)*4)
   {...}/            #    for j in Y:
      .39\-          #        q = 39 - j
      ' '*           #        print ' '*q  # print right number of spaces
      '/'            #        print '/'
      @2*            #        j *= 2
      '*'*           #        print '*'*j
      '\<NEWLINE>'   #        print "\\\n"
12,{...}/            # for i in range(12):
    ' '35*           #    print ' '*35
    '|'              #    print '|'
    @11<             #    i = i < 11
    '_-'1/=          #    z = "_-"[i] # pick "-" if i < 11, else pick "_"
    8*               #    print z*8
    1$               #    print '|' # (copy from earlier in the stack)
    n                #    print "\n"

1
Вы можете использовать тот же трюк с переводом строки, что и в моем решении. Вместо '\\'nввода новой строки в строку (+/- 0 символов) теперь не нужно экранировать обратную косую черту (-1 символ).
Говард

1
Еще два: 4*4+это то же самое, что )4*и '_-'[=]может быть написано, '_-'1/=что делает последнее +устаревшим.
Говард

3
объяснение может быть полезным ...? это слишком много, чтобы спросить?

@professfishfish: скоро!
Клавдиу

Тебе не нужен трейлинг ';' Вот? В противном случае будет два завершающих символа новой строки, так как golfscript по умолчанию добавляет один.
Набб

21

Haml & Sass

37 + 277 = 314

Haml:

%link(rel="stylesheet" href="s")
%pre

Sass:

pre:after{$l:"";@for$k from0 to10{@for$i from0 to4+$k{@for$j from0 to40-($k*6+$i*2)/2{$l:$l+' ';}$l:$l+'/';@for$j from0 to$k*6+$i*2{$l:$l+'*';}$l:$l+"\\\a ";}}@for$i from0 to12{@for$j from0 to35{$l:$l+" ";}@if$i<11{$l:$l+"|--------|\a ";}@else{$l:$l+"|________|";}}content:$l;}

* Sass позволяет управлять директивами, конкатенацией и разыменованием переменных. Все это полезно при моделировании, но многословно при игре в гольф.


генерируется в:

HTML:

<link rel="stylesheet" href="s" /><pre></pre>

CSS:

pre:after {
  content: "                                        /\\\a                                        /**\\\a                                       /****\\\a                                      /******\\\a                                      /******\\\a                                     /********\\\a                                    /**********\\\a                                   /************\\\a                                  /**************\\\a                                   /************\\\a                                  /**************\\\a                                 /****************\\\a                                /******************\\\a                               /********************\\\a                              /**********************\\\a                                /******************\\\a                               /********************\\\a                              /**********************\\\a                             /************************\\\a               
             /**************************\\\a                           /****************************\\\a                          /******************************\\\a                             /************************\\\a                            /**************************\\\a                           /****************************\\\a                          /******************************\\\a                         /********************************\\\a                        /**********************************\\\a                       /************************************\\\a                      /**************************************\\\a                          /******************************\\\a                         /********************************\\\a                        /**********************************\\\a                       /************************************\\\a                      /**************************************\\\a                     /******************************
**********\\\a                    /******************************************\\\a                   /********************************************\\\a                  /**********************************************\\\a                       /************************************\\\a                      /**************************************\\\a                     /****************************************\\\a                    /******************************************\\\a                   /********************************************\\\a                  /**********************************************\\\a                 /************************************************\\\a                /**************************************************\\\a               /****************************************************\\\a              /******************************************************\\\a                    /******************************************\\\a                   /**********************************
**********\\\a                  /**********************************************\\\a                 /************************************************\\\a                /**************************************************\\\a               /****************************************************\\\a              /******************************************************\\\a             /********************************************************\\\a            /**********************************************************\\\a           /************************************************************\\\a          /**************************************************************\\\a                 /************************************************\\\a                /**************************************************\\\a               /****************************************************\\\a              /******************************************************\\\a             /*****************************************************
***\\\a            /**********************************************************\\\a           /************************************************************\\\a          /**************************************************************\\\a         /****************************************************************\\\a        /******************************************************************\\\a       /********************************************************************\\\a      /**********************************************************************\\\a              /******************************************************\\\a             /********************************************************\\\a            /**********************************************************\\\a           /************************************************************\\\a          /**************************************************************\\\a         /****************************************************************\\\a        /*********
*********************************************************\\\a       /********************************************************************\\\a      /**********************************************************************\\\a     /************************************************************************\\\a    /**************************************************************************\\\a   /****************************************************************************\\\a  /******************************************************************************\\\a                                    |--------|\a                                    |--------|\a                                    |--------|\a                                    |--------|\a                                    |--------|\a                                    |--------|\a                                    |--------|\a                                    |--------|\a                                    |--------|\a                                    
|--------|\a                                    |--------|\a                                    |________|"; }

итоговая страница


1
Вы не видите тонны HTML / CSS решений на CodeGolf. Хорошая работа.
Мордред

16

CJam , 62 байта

A,{I4+,{I3*J+_39\-S*'/@2*'**'\N}fJ}fI{35S*'|'-8*'|N++}C*'-/'_*

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

Как это работает

A,           " Push [ 0  …  9 ].                                                   ";
{            " For each I in that array:                                           ";
  I4+,       " Push [ 0  …  I + 3 ].                                               ";
  {          " For each J in that array:                                           ";
    I3*J+_   " Push K := 3 * I + J twice.                                          ";
    39\-S*   " Push a string consisting of 39 - K spaces.                          ";
    '/       " Push a slash.                                                       ";
    @2*'**   " Push a string consisting of 2 * K asterisks.                        ";
    '\N      " Push a backslash and a linefeed.                                    ";
  }fJ        "                                                                     ";
}fI          "                                                                     ";
{            " Do the following 12 times:                                          ";
  35S*       " Push a string consisting of 35 spaces.                              ";
  '|         " Push a vertical bar.                                                ";
  '-8*'|++   " Push the string '--------|\n'.                                      ";
}C*          "                                                                     ";
'-/'_*       " Replace the hyphen-minus signs of the last string with underscores. ";

2
Я должен начать использовать CJam вместо GolfScript ...
Клаудиу

Что делает код CJam таким компактным? Это просто обычные функции хорошо сочетаются друг с другом или есть какой-то супер-трюк? Или это на самом деле не CJam, а программисты CJam?
Ви.

2
@Vi .: Это смесь обоих. 1. CJam основан на стеке, поэтому вы обычно обходитесь без использования каких-либо переменных. 2. Имена всех встроенных модулей имеют длину не более двух символов. Из-за этого вам не нужны пробелы, за исключением некоторых особых случаев. 3. Даже представления на языках игры в гольф сами по себе не играют в гольф. Мои программы GolfScript / CJam теперь намного короче, чем раньше.
Деннис

Предложение для CJam будет использовать коды ASCII 128-256 для всего другого набора встроенных модулей. есть специальный редактор, который
Клавдиу

@Claudiu: Ну, это до его создателя. Если бы я разработал свой собственный язык игры в гольф, я думаю, что я бы сделал его основанным на битах или арифметически закодировал бы все инструкции.
Деннис

15

GolfScript, 79 символов

10,{:^4+,{2*^6*+'*'*.,2/~40+' '*'/'@'\
'}/}/[' '35*]12*'|--------|
'*'||''_'8**

Попробуйте код здесь . Обратите внимание, что разрывы строк не являются обязательными в этом коде


24
Многострочное решение GolfScript? Я не думал, что увижу день!
Инго Бюрк

12

Python, 148 129 126 121 символов

R=range
for i in R(10):
 for j in R(i*3,4+i*4):print' '*(39-j)+'/'+'**'*j+'\\'
for c in'-'*11+'_':print' '*35+'|'+c*8+'|'

Спасибо Falko за сохранение 3 символов и flornquake за блестящее сохранение еще 5!


1
Умножение символов в Python слишком идеально для этой задачи ...
Шон Лэтэм

Подожди, пока не увидишь мое решение для игры в гольф ... = P
Claudiu

2
Используйте '**'*jдля сохранения 3 символов. Помимо этого мое решение сходится к точно такому же коду. :)
Фалько

1
Вы можете сделать последнюю строку короче, написав for c in'-'*11+'_':print' '*35+'|'+c*8+'|'.
землетрясение

@flornquake: хорошо! очень умно
Клаудиу

11

Bash, 236 197 193

10 байтов кода + 1-байтовое имя файла + 182-байтовый файл данных = всего 193 байта

zcat y 2>j

объяснение

yявляется файлом, содержащим Yggdrasil, без завершающей новой строки, сжатый с помощью алгоритма zopfli (вызывается как zopfli --i64), а затем с последними удаленными 8 байтами. zopfli совместим с gzip, поэтому я могу распаковать файл с помощью стандартных утилит Bash, разработанных для gzip. Размер файла данных составляет 182 байта (229 байтов при использовании обычного gzip). Размер исходного Yggdrasil, без новой строки, составляет 5876 байт.

Удаление последних 8 байтов вызывает сообщения об ошибках, которые подавляются отправкой стандартной ошибки в файл с именем j. Если jсуществует, он будет перезаписан.

Base64 из y(использоватьbase64 -d для получения оригинального файла):

H4sIAAAAAAACA+3SMQoCURDA0N5TWC+IFxK8yD/8Nul9hfDRnamT6J+du83zdUPwOACNNDb0+3Bs
tMPhSscDvusHgM9wIcUNclL+5r/luJXkmlh5rM3r8txkMdVNcEn1Nc2a1AU72XWz3Xd91r5z7eZD
AQKQgAI0PDFf8xJfExpQgQhkpAIdz8ytzK3AQMg6UMIQpLQELU/NQc5B/thBegtqHpOc16jHOX/v
x1mPZg19MfrdrBM=

И md5sum это:

4a049a80241160cdde0a3cbca323b7f2

2
Мой палец зудел, чтобы я нажал кнопку «удалить», когда увидел код, пока не прочитал количество символов и объяснения. : P
Дверная ручка

2
Вы можете сохранить около 30 байт, используя zopfli для создания сжатого файла. «zopfli --i100 y» возвращает 190-байтовый файл, который zcat может распаковать.
Гленн Рандерс-Персон

1
И еще несколько, если вы удалите последние 10 байтов и закроете STDERR.
Деннис

@ GlennRanders-Pehrson, спасибо за указание на это, я также отредактировал свой ответ на «Молярные массы соединений» codegolf.stackexchange.com/a/35613/16402, чтобы использовать zopfli, сохранив 37 байтов

@ Денис, оказалось, что это было 8 байтов (больше и биты ствола Иггдрасиля будут отсутствовать), спасибо

7

С 169

i;j;p(a,b){while(b--)putchar(a);}main(){for(;i++<10;)for(j=i*3-4;++j<i*4;p(32,39-j),p(47,1),p(42,j*2),puts("\\"));for(++i;i--;p(32,35),p(124,1),p(i?45:95,8),puts("|"));}

Не растянутый (и слегка распутанный):

int i;
int j;
void p(a,b) {
  while (b--) putchar(a);
}
void main() {
  for (;i++<10;) {
    for (j=i*3-4;++j<i*4;) {
      p(32,39-j);
      p(47,1);
      p(42,j*2);
      puts("\\");
    }
  }
  for (++i;i--;) {
    p(32,35);
    p(124,1);
    p(i?45:95,8);
    puts("|");
  }
}

7

Рубин - 100

puts (0..21).map{|i|i>9??\ *35+?|+(i>20??_:?-)*8+?|:(0..i+3).map{|y|?\ *(39-z=y+3*i)+?/+?**z*2+?\\}}

Помещает автоматически выравнивает, так что мы можем собрать все строки, даже во вложенных массивах. Требуется Ruby 1,9

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


Я думаю, что нужно несколько ведущих мест. Также работает с Ruby 1.9, а не с 1.8.
Скотт Лидли

7

PowerShell 104 101

0..9|%{(3*$_)..(3+$_*4)|%{" "*(39-$_)+"/"+"*"*2*$_+"\"}};0..11|%{" "*35+"|"+("-","_")[$_-eq11]*8+"|"}

6

C # 258 234 байта

Спасибо некоторому раздражающему пользователю за предложенные правки, хорошо использующие метод String.PadLeft!

using System;class G{static void Main(){Action<string>p=Console.WriteLine;int i=0,j;for(;i++<10;)for(j=i*3-3;j++<i*4;)p("/".PadLeft(41-j)+"\\".PadLeft(2*j-1,'*'));while(i-->0)p("|--------|".PadLeft(45));p("|________|".PadLeft(45));}}

Код довольно прост, не так много осталось для гольфа.

Форматированный код:

using System;
class G
{
    static void Main()
    {
        Action<string> p = Console.WriteLine;
        int i = 0, j;
        for(; i++ < 10 ;)
            for(j = i*3 - 3; j++ < i*4;)
                p("/".PadLeft(41 - j) + "\\".PadLeft(2*j - 1,'*'));
        while(i-- > 0)
            p("|--------|".PadLeft(45));
        p("|________|".PadLeft(45));
    }
}

Использовать \rздесь бессмысленно. Это код гольф.
nyuszika7h

3
@ nyuszika7h действительно, но он включен в отформатированную копию, чтобы люди, использующие блокнот, могли легче увидеть славу Иггдрасиля (он не включен в партитуру)
VisualMelon

А ну понятно. Windows ... Не стесняйтесь исправить мои изменения тогда.
nyuszika7h

@ nyuszika7h спасибо за то, что указали на неправильное выделение синтаксиса
VisualMelon


4

Perl, 127

for$i(0..9){for$j($i*3..3+$i*4){print" "x(39-$j),"/","*"x($j*2),"\\\n";}}for$i(0..11){print" "x35,"|",($i>10?"_":"-")x8,"|\n";}

Ungolfed:

for $i (0..9) {
  for $j ($i*3..3+$i*4) {
    print " "x(39-$j) , "/" , "*"x($j*2) , "\\\n";
  }
}
for $i (0..11) {
  print " "x35 , "|" , ($i>10?"_":"-")x8 , "|\n";
}

Замените $ i на $ _ и сохраните 4 символа.
Чороба

4

Рубин - 139 129 126 123 121

Hoisted "ставит" вне создания массива (предложение от bitpwner).

puts (0..9).map{|i|(i*3...(i+1)*4).map{|j|"/#{'**'*j}\\".rjust(41+j,' ')}}+["%45s"%'|--------|']*11<<'%45s'%'|________|'


Ungolfed («ставит» без подков)


# print fill patterns from the intervals
# [0..3, 3..7, 6..11, 9..15, 12..19, 15..23, 18..27, 21..31, 24..35, 27..39]
# centered on columns 81-82
(0..9).each { |i|
  (i*3...(i+1)*4).each { |j|    # x...y vs x..y-1 saves a char
    puts "/#{'**'*j}\\".rjust(41+j,' ')
  }
}
# print the stump
puts ("%45s\n" % '|--------|') * 11
puts '%45s' % '|________|'

@bitpwner Я думаю, это заслуживает отдельного ответа. Действуй.
Скотт Лидли

4

PHP 223 202 181 160 156

Редактировать Я понял, как создать псевдоним для функции с переменной, и смог отрубить еще несколько символов. Чтоstr_repeat функция была действительно многословна

Редактировать 2: Спасибо всем за предложения!

Golfed:

<?$s=str_repeat;for($i=-1;$i++<9;)for($j=$i*3;$j<4+$i*4;)echo$s(' ',39-$j).'/'.$s('**',$j++)."\\
";for($i=12;$i--;)echo$s(' ',35),'|'.$s($i?'-':'_',8)."|
";

Удобочитаемый:

    <?

$s=str_repeat;

for($i=-1;$i++<9;)
{
    for($j=$i*3;$j<4+$i*4;)
    {
        echo$s(' ',39-$j).'/'.$s('**',$j++)."\\
        ";
    }
}

for($i=12;$i--;)
{
    echo$s(' ',35),'|'.$s($i?'-':'_',8)."|
    ";
}

Вывод: http://brobin.me/yggdrasil.php


Вы можете сохранить 6 символов, удалив круглые скобки (39-$j), ($j*2)и ($i==11). -2, заменяя \nреальными символами новой строки (PHP позволяет это в литералах). -5 символов, заменив (оба) for($i=0;$i<12;$i++)на for($i=12;$i-->0;)и $i==11с $i==0.
sebcap26

После этого вы также можете заменить $s(($i==0?'_':'-'),8)на $s($i?'-':'_',8). (==> -5 символов)
sebcap26

-1 Символ, заменяя $s('*',$j*2)на $s('**',$j). Я думаю, что это последнее улучшение, которое я могу найти.
sebcap26

-2 изменение ($j*2)во внутреннем для ($j++*2)и удаление $j++из for()аргументов
Авал

@ sebcap26 for($i=12;$i-->0;)можно сократить до for($i=12;$i--;)- еще 2 символа.
Avall

3

Delphi 429

Попробую улучшить позже.
Golfed

uses strutils,SysUtils,Classes;const a='|----';b='|____';c:array [0..9,0..1]of int32=((0,3),(3,7),(6,11),(9,15),(12,19),(15,23),(18,27),(21,31),(24,35),(27,39));var t:TStrings;i,j:integer;begin t:=tstringlist.Create;for I:=0to 9do for J:=c[i,0]to c[i,1]do t.Add('/'+StringOfChar('*',j));for I:=0to 10do t.Add(a);t.Add(b);for I:=0to t.Count-1do t[i]:=t[i].PadLeft(40)+ReverseString(t[i]).Replace('/','\');write(T.TEXT);readln;end.

ungolfed

uses
  strutils,SysUtils,Classes;
const
  a='|----';
  b='|____';
  c:array [0..9,0..1]of int32=((0,3),(3,7),(6,11),(9,15),(12,19),(15,23),(18,27),(21,31),(24,35),(27,39));
var
  t:TStrings;
  i,j:integer;
begin
  t:=tstringlist.Create;
  for I:=0to 9do
    for J:=c[i,0]to c[i,1]do
      t.Add('/'+StringOfChar('*',j));
  for I:=0to 10do
    t.Add(a);
  t.Add(b);
  for I:=0to t.Count-1do
    t[i]:=t[i].PadLeft(40)+ReverseString(t[i]).Replace('/','\');
  write(T.TEXT);
  readln;
end.

3

Javascript, 288 281

Chrome скрывает дубликаты console.logs, используйте IE.

function t(w){s="";for(i=0;i++<39-w;)s+=" ";s+="/";for(i=0;i++<w*2;)s+="*";return s+"\\"}function r(l){s="";for(i=0;i++<36;)s+=" ";s+="|";for(i=0;i++<8;)s+=l;return s+"|"}w=0;c=console;for(h=0;h++<10;){for(j=0;j++<3+h;)c.log(t(w++));w-=h}for(j=0;j++<11;)c.log(r('-'));c.log(r('_'))

Ungolfed:

function t(w)
{
    s="";
    for(i=0;i++<39-w;)
        s+=" ";
    s+="/";
    for(i=0;i++<w*2;)
        s+="*";
    return s+"\\"
}
function r(l)
{
    s="";
    for(i=0;i++<36;)
        s+=" ";
    s+="|";
    for(i=0;i++<8;)
        s+=l;
    return s+"|"
}

w=0;
c=console;
for(h=0;h++<10;)
{
    for(j=0;j++<3+h;)
        c.log(t(w++));
    w-=h;
}
for(j=0;j++<11;)
    c.log(r('-'));
c.log(r('_'))

Используйте for(i=0;i++<39-w;)вместо for(i=0;i<39-w;++i)и так далее. Кроме того, p=console.logвместо c=consoleи pвместо c.log(хотя я проверял только последний в Node.js, он не работает в Firefox). Это экономит 12 байтов.
nyuszika7h

c=console.logв Chrome тоже не работал, поэтому я его не использовал. Трюки цикла for экономят 7 байт.
Шон Лэтэм

Я обычно очень осторожен со всем, что побуждает меня использовать MSIE ...

Вполне возможно, это первый раз, когда я видел фразу «используйте вместо этого IE». О_о Однако вы можете подавить поведение Chrome, просто запустив этот код в консоли, а не с веб-страницы.
Ручка двери

Запуск его на странице и в консоли дает одинаковые результаты для меня как в Firefox, так и в Chrome.
Шон Лэтэм

3

JavaScript (console.log), 168 166

(Пробелы только для удобства чтения)

for(i=c=0;i<11;i++)
  for(j=0;j<4+i&!c;j++)
    l=i*13+j,
    a=Array(n=i-10?3*i+j+1:5).join("*-_"[k=(l>129)+(c=l==141)]),
    console.log(Array(41-n).join(" ")+'/||'[k]+a+a+'\\||'[k])

3

С (219)

Спасибо всем за советы по игре в гольф - удалось довести их до 219. Не думаю, что это будет намного ниже.

w,W,s,S,i,r;main(){char T[78];memset(T,42,78);for(r=4,s=39;r<14;++r,s-=3,w+=6)for(i=0,S=s,W=w;i<r;++i,W+=2,--S)printf("%*s/%.*s\\\n",S,"",W,T);for(i=0;i<11;i++)printf("%35s|--------|\n","");printf("%35s|________|","");}

Обязательно включает в себя:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

Если он хочет использовать C89, он также может опустить все включения. В этом коде нет случая, когда неявное объявление о вызове облажалось.
Джошуа

@Nax; это приводит меня к 263 - и я вытащил включает. Спасибо.
DreamWarrior

@ Joshua - 64-битные системы и memset могут быть проблематичными, но ... в противном случае, возможно, нет. В любом случае, большинство людей удаляют включения, так что я тоже.
DreamWarrior

На самом деле это 262 символа, вам не нужен завершающий перевод строки.
nyuszika7h

Вы можете использовать 32вместо ' 'и 42вместо '*':)
Квентин

3

Хаскелл, 153 148

Прямо вперед, никаких хитростей, просто игра в гольф:

(a:b:c)%n=(39-n)&' '++a:(2*n)&b++c
n#m=[n..m]++(n+3)#(m+4)
(&)=replicate
main=putStr$unlines$map("/*\\"%)(take 85$0#3)++map("|-|"%)(11&4)++["|_|"%4]

%Оператор рисует одну линии, ее первый аргумент будучи Stringдлиной 3 , содержащие границы и символы заполнения в этой строке (теперь предполагающей ровно 3 Charсек, экономя 5 байт), то во- вторыхи, Int, определяет половину число заполнения символов. Сопоставление, сопоставление и добавление в шаблон используется в комбинации, чтобы сохранить байты, заботясь о «склеивании» между Charи String. Во второй версии я также сделал #бесконечным и представилtake 85 чтобы сделать его снова конечным (к сожалению, не было сохранено ни одного байта).

#Оператор создает последовательность для nаргумента , %необходимые для дерева: [0..3], [3..7], ...сцеплены.

& это просто инфикс сокращение для replicate , которое происходит три раза.

Дерево собрано в последней строке, новые строки добавлены unlines.



2

Луа - 164

a=' 'for i=0,9 do for j=i*3,3+i*4 do print(a:rep(39-j)..'/'..(('*'):rep(j*2))..'\\')end end for i=0,11 do print(a:rep(35)..'|'..((i>10 and'_'or'-'):rep(8))..'|')end

2

Mathematica 191 178

Конечно, не лучшее решение:

n=Nest;
t=Table;
""<>
    t[
        {n[#<>" "&,"",39-i],"/",n[#<>"*"&,"",2i],"\\\n"}
    ,
        {i,Flatten@t[Range[j+4]-1+3j,{j,0,9}]}
    ]
<>
    t[
        n[#<>" "&,"",35]<>If[i==12,"|________|\n","|--------|\n"]
    ,
        {i,12}
    ]

Не считая новых строк. Mathematica искажает вывод, так как для пробела он не принимает ту же ширину, что и для «*» и «/». Но результат верный.


(это мой первый гольф)
freddieknets

2

Ява - 286

Мой первый гольф.

Golfed:

class M{public static void main(String[]args){int i=0,a,f=0;String s="";for(;i++<11;){for(a=i*3-4;++a<i*4;){if(i>10){a=4;if(++f>12)break;}s+=s.format("%"+(40-a)+"s"+(a>0?"%0"+a+"d":"")+"%3$s",f>0?"|":"/",0,f>0?"|":"\\").replace("0",f<1?"**":f>11?"__":"--")+"\n";}}System.out.println(s);}}

Ungolfed:

class M {
    public static void main(String[] args) {
        int i=0,a,f=0;
        String s = "";
        for(;i++<11;){
            for(a=i*3-4;++a<i*4;a++){
                if(i>10){
                    a=4;
                    if(++f>12)break;
                }
                s+=s.format("%"+(40-a)+"s"+(a>0?"%0"+a+"d":"")+"%3$s",f>0?"|":"/", 0,f>0?"|":"\\").replace("0", f<1?"**":f>11?"__":"--")+"\n";
            }
        }
        System.out.println(s);
    }
}

Тест здесь


2

Python 2, 117

j=0
while j<40:j-=j/4;exec(j/3+4)*r"print' '*(39-j)+'/'+'**'*j+'\\';j+=1;"
for c in'-'*11+'_':print' '*35+'|'+c*8+'|'

Другие версии, которые я пробовал, включают в себя:

# 118
for i in range(10):j=i*3;exec(i+4)*r"print' '*(39-j)+'/'+'**'*j+'\\';j+=1;"
for c in'-'*11+'_':print' '*35+'|'+c*8+'|'

# 118
i=j=4
while j:j=52-3*i;exec"j-=1;print' '*j+'/'+'**'*(39-j)+'\\\\';"*i;i+=1
for c in'-'*11+'_':print' '*35+'|'+c*8+'|'

# 118
j=0
for b in'\\'*10:j-=j/4;exec(j/3+4)*"print' '*(39-j)+'/'+'**'*j+b;j+=1;"
for c in'-'*11+'_':print' '*35+'|'+c*8+'|'

# 119
s=40
while s:s+=10-s/4;exec(52-s)/3*r"s-=1;print' '*s+'/'+'**'*(39-s)+'\\';"
for c in'-'*11+'_':print' '*35+'|'+c*8+'|'

2

Pyth, 101 100 99 90 81 байт

J0Km/*+d7d2S9V85FTKI!-TN=hZ=+JZ))+*d-39-NJ++\/*"**"-NJ\\)Va*]\-11\_+++*d35\|*N8\|

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

Перевод Python 3:
Z=0
d=" "
J=0
K=list(map(lambda d:((d+7)*d)//2,range(1,10)))
for N in range(85):
    for T in K:
        if not T-N:
            Z+=1
            J+=Z
    print(d*(39-(N-J))+"/"+"**"*(N-J)+"\\")
for N in ["-"]*11+["_"]:
    print(d*35+"|"+N*8+"|")

Разве aфункция, определенная в вашем Python, не эквивалентна +спискам?
Esolanging Fruit

@EsolangingFruit Это близко, но не совсем: <list>+<str>это недопустимая операция, но я мог бы также легко использовать ["-"]*11+["_"]. Я решил определить свою собственную функцию, чтобы точнее перевести то, что фактически делает Пит.
hakr14

Хорошо, это имеет смысл.
Esolanging Fruit

2

Powershell, 88 байт

0..9|%{(3*$_)..(3+$_*4)|%{' '*(39-$_)+"/$('**'*$_)\"}}
,'-'*10+'_'|%{' '*35+"|$($_*8)|"}

1

Groovy 118

10.times{(it*3).upto 3+it*4,{println' '*(39-it)+'/'+'*'*it*2+'\\'}};12.times{println' '*35+'|'+(it>10?'_':'-')*8+'|'}

1
Почему я не удивлен, увидев довольно короткое решение Groovy. У меня сложилось впечатление, что Groovy сделал это Java-программист, который ненавидел печатать.
Almo

1

С, 194

Этот код - горячий беспорядок и определенно может быть больше в гольфе. Тем не менее, это была возможность опробовать пару вещей, которых я никогда не делал раньше: использование литерала для строки звездочек и использование спецификатора ширины *со строкой в printf.

i,j=5,k=5,n;
main(){
  char d[]={[0 ...77]=42,0};
  for(;i<85;i++)k--,j+=!k,k+=(j-1)*!k,n=39-i+(j-5)*(j-4)/2,printf("%*s/%s\\\n",n,"",d+n*2);
  for(;i<97;i++)printf("%*s|\n",44,i-96?"|--------":"|________");
}

1

Ракетка 223 220 211 204 198

Golfed:

(for-each display(flatten(let([m make-list])`(,(for*/list([i 10][j(range(* i 3)(* 4(+ 1 i)))])`(,(m(- 39 j)" ")"/",(m j"**")"\\\n")),(for/list([c`(,@(m 11"-")"_")])`(,(m 35" ")"|",(m 8 c)"|\n"))))))

Ungolfed:

(for-each display
     (flatten
      (let([m make-list])
        `(,(for*/list([i 10][j(range(* i 3)(* 4(+ 1 i)))])
             `(,(m(- 39 j)" ")"/",(m j"**")"\\\n"))
          ,(for/list([c`(,@(m 11"-")"_")])
             `(,(m 35" ")"|",(m 8 c)"|\n"))))))

1

Сборка (MIPS, SPIM) , 768 671 659 655 654 байта

.text
.globl main
main:
li $8 32
li $9 47
li $t2 42
li $t3 92
li $t4 10
li $t5 42
addi $sp -4
move $4 $sp
la $s6 q
la $s5 w
li $t8 0
li $s0 10
li $t9 0
li $s3 40
li $s2 39
q:
sub $s3 $s3 $t8
add $s2 $s2 $t8
addi $t7 $t8 3
addi $t8 1
blt $s0 $t8 e
r:
sw $0 ($4)
blt $t9 $s2 t
beq $t9 $s2 y
beq $t9 $s3 u
beqz $t7 i
sb $t2 ($4)
p:
li $2 4
syscall
addi $t9 1
ble $t9 $s3 r
move $t9 $0
j $s5
o:
addi $t7 -1
bgez $t7 r
jr $s6
w:
addi $s2 -1
addi $s3 1
j o
t:
sb $8 ($4)
j p
y:
sb $9 ($4)
j p
u:
sb $t4 1($4)
sb $t3 ($4)
j p
i:
sb $t5 ($4)
j p
e:
li $t1 124
li $t3 124
li $t2 45
li $t5 95
li $t7 11
la $s6 a
la $s5 o
li $s2 35
li $s3 44
j r
a:
li $2 10
syscall

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

Редактирование: Сохранение ~ 100 байт путем жесткого кодирования каждого символа в регистре и простой записи в стек, а затем злоупотребления тем фактом, что MIPS не имеет типов, поэтому допускается неявное слово в строку ascii.
Редактировать 2: удален дубликат стека. ( addi $sp -4) Ой!
Правка 3: при перезаписи случайно сделал пень 1 символ слишком коротким. (36 вместо 35). Исправлена.
Отредактируйте 4: -4 байта, используя $ 8 и $ 9 вместо $ t0 и $ t1. они означают одно и то же, но $ t0 легче читать. к сожалению, все другие t-регистры имеют одинаковую длину при правильном написании ($ t2 == $ 10, но оба по 3 символа), поэтому все остальные являются стиркой. Я мог (теоретически) использовать оставшиеся регистры 'a' (5-7. Print syscall использует 4), но на самом деле поведение не определяется при использовании syscall.
-1 байт, устанавливая t8 в 0 и переходя на меньшее, чем на равное. также потребовал, чтобы я переупорядочил операции добавления, что, к сожалению, привело к увеличению времени выполнения на 3 огромных кода операции.

Не самый лучший в MIPS, но после очищения моей совести от этого в мета-дискуссии я отправляю их. MIPS не предназначен для этого (нет вывода, нет для циклов), но довольно забавно сделать это, возможно, несмотря на это.

К сожалению, я не создал закомментированную версию для этого нового решения, но вы можете просмотреть старую версию с полной документацией здесь

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


так как это решение не требует .data, можно преобразовать в двоичный (скомпилированный) и сохранить кучу байтов. однако SPIM не поддерживает его, так что c'est la vie.
Эндрю Баумер

Кроме того , я не уверен , что если стенографии , addi $sp -4которая на самом деле addi $sp $sp -4от SPIM или MIPS в целом, так что если кто - либо другой, пожалуйста , дайте мне знать.
Эндрю Баумер

0

Кобра - 166 228 260

class P
    def main
        for x in 10,for n in 4+x,print' '.repeat(39-x*3-n)+'/['**'.repeat(x*3+n)]\\'
        w=' '.repeat(35)
        print'[w]|--------|\n'.repeat(11)+w+'|________|'
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.