Поместите планер!


17

Эта:

введите описание изображения здесь

это планер .

В игре жизни Конвея планер - известная фигура, которая быстро распространяется по доске. Для сегодняшнего испытания мы нарисуем художественную доску Game of Life ASCII и поместим на нее планер.

Доска, с которой мы начинаем, это:

|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|_|_|

Эта доска полностью состоит из труб |и подчеркиваний _и имеет размер 10х10. Вы должны написать программу или функцию, которая принимает два целых числа, «x» и «y», и выводит эту же доску с планером в этих координатах. Например, если у вас был планер в позиции (1, 1)(с индексом 0), вы должны вывести следующее:

|_|_|_|_|_|_|_|_|_|_|
|_|_|*|_|_|_|_|_|_|_|
|_|_|_|*|_|_|_|_|_|_|
|_|*|*|*|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|_|_|

Вы можете предположить, что планер никогда не будет размещен вне границ, поэтому x и y всегда будут в [0-7]диапазоне. Вы также можете принять координаты 1 с индексами, но вы должны указать это в своем ответе. В этом случае входы всегда будут в [1-8]диапазоне. Вот несколько примеров (все с 0 индексами):

0, 0:
|_|*|_|_|_|_|_|_|_|_|
|_|_|*|_|_|_|_|_|_|_|
|*|*|*|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|_|_|

7, 7:
|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|*|_|
|_|_|_|_|_|_|_|_|_|*|
|_|_|_|_|_|_|_|*|*|*|

7, 4:
|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|*|_|
|_|_|_|_|_|_|_|_|_|*|
|_|_|_|_|_|_|_|*|*|*|
|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|_|_|

5, 2:
|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|*|_|_|_|
|_|_|_|_|_|_|_|*|_|_|
|_|_|_|_|_|*|*|*|_|_|
|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|_|_|
|_|_|_|_|_|_|_|_|_|_|

Как обычно, вы можете принять IO в любом разумном формате. Это включает, но не ограничивается строкой с символами новой строки, массивом строк, двумерным массивом строк или записью в файл / STDOUT. Вы также можете выбрать, в каком порядке брать x и y .

Поскольку это , стандартные лазейки запрещены и делают самый короткий код, какой только можно!


Можем ли мы изменить угол, который определяет положение планера?
Стивен

@StephenS Нет, координаты должны определять, где начинается левый верхний угол планера.
DJMcMayhem


2
the glider is a famous pattern that slowly traverses across the boar., Медленно? Это самый быстрый диагональный движущийся объект в GoL. Он достигает 1/4 скорости света.
Кристоф

1
@ Кристофф, хорошая мысль, мы можем заметить, что его длина, по-видимому, не сжимается в направлении движения, но я не знаю никакого способа измерения его массы на релятивистских скоростях.
Wossname

Ответы:



5

V , 31 , 30 байт

10O±°_|ÀGjjÀ|3r*kr*kh.Í*ü_/|&

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

HexDump:

00000000: 3130 4fb1 b05f 7c1b c047 6a6a c07c 3372  10O.._|..Gjj.|3r
00000010: 2a6b 722a 6b68 2ecd 2afc 5f2f 7c26       *kr*kh..*._/|&

Он принимает входные данные в качестве аргументов программы и индексируется 1.

Объяснение:

10O                         " On the following 10 lines, insert:
   ±°_                      "   10 '_' characters
      |                     "   And a '|'
       <esc>                " Return to normal mode
            ÀG              " Go to the a'th line
              jj            " Move down two lines
                À|          " Go to the b'th column
                  3r*       " and replace the next 3 characters with asterisks
                     k      " Move up a line
                      r*    " And replace this char with an asterisk
                        kh  " Move up a line and to the left
                          . " And repeat the last change we performed (replace with asterisk)
                            "
Í                           " On every line, substitute:
 *                          "   An asterisk
  ü                         "   OR
   _                        "   An underscore
    /                       " With:
     |&                     "   A bar followed by the matched pattern

Два вопроса: что? и как?
Pureferret

1
@Pureferret два ответа: языки гольфа, НАУКА (или он написал V XD)
Кристофер

1
@Pureferret Я добавил объяснение.
DJMcMayhem

2

Желе , 37 35 байт

ȷ2b1
Ḍ+“£Æßæç‘Ṭ+¢s⁵j3;0$€Fṭ0ị“_*¶|”

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

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

ȷ2b1                             - the literal [1,1,1,1,...,1,1,1] with 100 elements
Ḍ+“£Æßæç‘Ṭ+¢s⁵j3;0$€Fṭ0ị“_*¶|”   - input (x,y)
Ḍ                                - convert (x,y) to 10*x+y
 +                               - add, to get the five "*" positions,
  “£Æßæç‘                        - the literal [2,13,21,22,23]
         Ṭ                       - return an array with those positions as truthy elements
          +¢                    - Now we format: pad to length 100 with the above literal
            s⁵j3                 - add newlines (represented by 3) to each set of 10
                ;0$€F            - add pipes (represented by 0) to each
                     ṭ0          - add a 0 to the beginning
                       ị“_*¶|”   - index into the string “_*¶|”

1
Как вы печатаете / генерируете свои программы?
RobotCaleb

1
@RobotCaleb: обычно от копирования вставки из кодовой страницы желе . Я запускаю их на TIO Nexus, когда не на своей основной машине, и клон репозитория Jelly на моем главном компьютере.
fireflame241

2

Python 2 , 151 байт

Будет гольф больше.

def f(x,y):r,x=[list('|_'*10+'|')for i in[1]*10],x*2;r[y][x+3]=r[y+1][x+5]=r[y+2][x+1]=r[y+2][x+3]=r[y+2][x+5]='*';print'\n'.join(''.join(i)for i in r)

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


Если вы хотите переключиться на Python 3, вы можете сохранить 3 байта, используя [*'|_'*10+'|']вместо list()вызова.
L3viathan

2

Perl 6 , 88 байт

->\x,\y{(^10 »*»i X+ ^10).map:{<|* |_>[$_!=
(1-2i|2-i|0|1|2)+x+y*i+2i]~"|
"x(.re==9)}}
  • Комплексные числа используются для представления координат.

  • ^10 »*» i X+ ^10 генерирует сетку всех комплексных чисел с целочисленными компонентами от нуля до девяти.

  • Возвращает список строк, каждая из которых содержит одну строку.


Интересно, я не знал, что Perl использует не-ASCII. Что делает »? Как это закодировано?
DJMcMayhem

1
Это просто ПРАВИЛЬНАЯ ТОЧКА Юникода, U + 00BB, закодированная в UTF-8. В Perl 6 это также можно записать в виде двух угловых скобок, >>но это то же количество байтов, что и в гильемете, поэтому для игры в гольф я предпочитаю последнее, так как оно выглядит немного класснее ИМХО. Что касается того, что он делает, он превращает окружающий его оператор в «гипероператор», который попарно применяется к спискам или значениям с обеих сторон. Здесь он умножает каждый элемент диапазона 0-9на i, давая 0, i, 2i, ..., 9i.
Шон

1

Haskell , 96 байт

r=[0..9]
x#y=['|':(r>>=(\i->[last$'_':['*'|elem(i-x,j-y)$zip[1,2,0,1,2][0,1,2,2,2]],'|']))|j<-r]

Принимает два целых числа ( xи y) и возвращает список Strings, то есть двухмерный список типа [[Char]].


Тестирование:

import System.Environment

main :: IO ()
main = do
    args <- getArgs
    let (x, y) = (read $ args !! 0, read $ args !! 1)
    mapM_ putStrLn (x#y)


1

Математика, 115 113 байтов

x(a="|_"~Table~10~Table~10;(a[[##]]="|*")&@@(#+x)&/@({{0,1,2,2,2},{1,2,0,1,2}});""<>Riffle[#<>"|"&/@a,"\n"])

где

Это принимает вклад в {row, col} формате и индексируется 1, но может быть преобразован в индекс 0 без добавления байтов.

Некоторые заметки:

  1. \n символ новой строки, занимает 1 байт.
  2. является \[Function], занимает 3 байта.
  3. есть \[Transpose], занимает 3 байта.

Обратите внимание, что «массив строк» ​​разрешен, поэтому я могу просто удалить Riffle , дает

Mathematica, 98 97 байт

x(a="|_"~Table~10~Table~10;(a[[##]]="|*")&@@(#+x)&/@({{0,1,2,2,2},{1,2,0,1,2}});#<>"|"&/@a)

1

Java 8, 165 144 байта

x->y->{String r="";for(int i=0,j;++i<11;r+="\n")for(r+="|",j=0;++j<11;)r+=(i==x&j==y+1)|(i==x+1&j==y+2)|(i==x+2&j>=y&j<y+3)?"*|":"_|";return r;}

Объяснение:

Попробуй это здесь.

x->y->{                  // Method with two integer parameters and String return-type
  String r="";           //  Result-String
  for(int i=0,j;++i<11;  //  Loop (1) over the rows
     r+="\n|")           //    And after each iteration add a new-line to the result-String
    for(r+="|",          //   Start by appending "|" at the start of the line
      j=0;++j<11;        //   Loop (2) over the columns
      r+=(i==x&j==y+1)|(i==x+1&j==y+2)|(i==x+2&j>=y&j<y+3)?
                         //    If this coordinate should contain a '*'
        "*|"             //     Append "*|"
       :                 //    Else:
        "_|"             //     Append "_|"
    );                   //   End of loop (2)
                         //  End of loop (1) (implicit / single-line body)
  return r;              //  Return the result-String
}                        // End of method

1
Объяснение имеет другой код, чем ваш ответ? Посмотрите на первое задание к р.
КОМПЬЮТРОНИУМ

@Computronium Упс, спасибо, что заметили, исправлено. Подсчет был правильным, объяснение было правильным, TIO-ссылка была правильной, но фактический ответ был все еще старый неправильный ..
Кевин Круйссен

1

JavaScript (ES6), 99 байт

x=>y=>eval('for(i=0,o="";i<101;o+=((d=i-x-y*10)==1|d==12|d>19&d<23?"|*":"|_")+(++i%10?"":`|\n`))o')

Принимает ввод через карри: f(5)(2) для x = 5, y = 2. Координаты с нулевой индексацией.

Тестовый фрагмент

f=
x=>y=>eval('for(i=0,o="";i<101;o+=((d=i-x-y*10)==1|d==12|d>19&d<23?"|*":"|_")+(++i%10?"":`|\n`))o')

xi.oninput=yi.oninput=_=>O.innerHTML=f(xi.value)(yi.value)
O.innerHTML=f(xi.value=5)(yi.value=2)
<style>*{font-family:Consolas;}input{width:2.5em;}</style>
x: <input id="xi" type="number" min="0" max="7">,
y: <input id="yi" type="number" min="0" max="7">
<pre id="O">


0

СОГЛ , 23 байта

LIΖ|_ΟL∙.«."¾'┼ΞΧ⌠²‘5nž

примечание: ожидается, что вход будет 1 проиндексирован

Объяснение:

LI                       push 11
  Ζ|_                    push "|" and "_"
     Ο                   make an altrenates string [with 11 separators, which are "|" and parts "_"]
      L∙                 get an array of 10 of those
        .«               take input and multiply by 2 (x pos)
          .              take input (y pos)
           "¾'┼ΞΧ⌠²‘     push "_|*|__|_|**|*|*" - the glider in the map
                    5n   split into an array with items of length 5
                      ž  replace in the 1st [grid] array at positions [inp1*2, inp2] to 2nd array [glider]


0

Древесный уголь , 28 байт

UO²¹χ|_J×N²N“ "}IyE%%mLBMφ/”

Попробуйте онлайн! Ссылка на подробный режим для описания.


Я разочарован тем, что древесный уголь не ... ну, только ASCII;)
Beta Decay

Вы можете удалить |_перед \nсохранением сжатый байт. (Я пробовал несколько разных способов печати планера, но ни один из них не сохранил байты.)
Нил
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.