Полотна рицарська послідовність


10

Вступ

Натхненний дуже недавним відео The Trapped Knight - Numberphile , я підійшов до виклику.

Пастка послідовність лицаря є кінцева ціле число послідовність довжини 2016 року, починаючи з 1, і має наступні правила будівництва:

  1. Напишіть числову спіраль таким чином:
17 16 15 14 13 ...
18  5  4  3 12 ...
19  6  1  2 11 ...
20  7  8  9 10 ...
21 22 23 24 25 ...
  1. Помістіть лицаря на 1.
  2. Перемістіть лицаря до сітки з найменшим числом, яке він може пройти, який раніше не відвідували, згідно з шаховими правилами (тобто 2 одиниці вертикально та 1 одиниця по горизонталі, або навпаки).
  3. Повторюйте, поки лицар не застрягне.

Ось перші три кроки:

Крок 1

 17  [16]  15  [14]  13 
[18]   5    4    3  [12]
 19    6  < 1>   2   11 
[20]   7    8    9  [10]
 21  [22]  23  [24]  25 

Можливі ходи - 10, 12, 14, 16, 18, 20, 22, 24, серед яких найменший - 10, тому другий член - 10.

Крок 2

  4  [ 3]  12  [29]  54
( 1)   2   11   28  [53] 
  8    9  <10>  27   52 
[23]  24   25   26  [51] 
 46  [47]  48  [49]  50 

Можливі рухи - 1 , 3, 23, 29, 47, 49, 51, 53, серед яких найменший - 3, тому третій член - 3.

Крок 3

 35  [34]  33  [32]  31 
[16]  15   14   13  [30] 
  5    4  < 3>  12   29 
[ 6] ( 1)   2   11  [28] 
  7  [ 8]   9  (10)  27 

Можливі рухи - 6, 8, 10 , 16, 28, 30, 32, 34, серед яких найменший - 6, тому четвертий додаток - 6.

Послідовність позначається зірочкою:

1 10 3 6 9 4 7 2 5 8 11 14 ...

і закінчується с

... 2099 2284 2477 2096 2281 2474 2675 2884 3101 2880 2467 2084

Виклик

Напишіть найкоротшу програму або функцію, отримавши ціле число в діапазоні [1, 2016](або [0, 2015]якщо використовується 0-індексований) як вхідний, виведіть число в цьому індексі у захопленій рицарській послідовності. Ви можете індексувати послідовність за допомогою 0-індексованої або 1-індексованої, але потрібно вказати, яку схему індексації ви використовуєте.

Тестові приклади (1-індексований)

n    | s(n)
-----+-----
   1 |    1
   2 |   10
   3 |    3
   6 |    4
  11 |   11
  21 |   23
  51 |   95
 101 |   65
 201 |  235
 501 |  761
1001 | 1069
2001 | 1925
2016 | 2084

Для всіх можливих результатів зверніться до цієї сторінки .

Критерії виграшу

Виграє найкоротший код кожної мови. Діють обмеження на стандартні лазівки.



1
@Arnauld Це питання надихнуло моє (як зазначено), але тільки швидше пройти головне. Також ця послідовність є кінцевою, тому деякі аспекти в гольфі можуть бути різними в цьому сенсі.
Шиеру Асакото

1
Інша послідовність також кінцева, зупиняючись на площі12851850258
Jo King

2
@JoKing Добре, але оскільки це зупиняється досить швидко, я хотів би побачити відповіді в езоланг з меншими цілими діапазонами (чи є езоланги, що реалізують 16-бітні цілі числа?)
Shieru Asakoto

1
Ну, якщо це питання було опубліковано першим у пісочниці, це не означає, що дуп був би іншим питанням ?
Luis felipe De

Відповіді:


4

JavaScript (ES7),  182  181 байт

f=(n,[x,y]=[2,1],a=[...Array(4e3)].map((_,n)=>[1,-1].map(s=>(i&1?-s:s)*(i+s*n-(n>0?n:-n)>>1),i=n**.5|0,n-=i*++i)))=>n--?f(n,a.find(([X,Y],j)=>(i=j,(x-X)*(y-Y))**2==4),a,a[i]=[]):i+1

Спробуйте в Інтернеті!

Як?

Трохи модифікована версія моєї відповіді на «Шлях до Гну» , безумовно, коротша (і швидша) від цього. Але я хотів спробувати інший підхід. Між іншим, я думаю, що може бути простіше реалізувати цей метод у деяких езолангах.

Алгоритм:

  1. 3199 рік
  2. (Х,Y)

    ((х-Х)×(у-Y))2=4

    (х,у)

    |х-Х|=1|у-Y|=2|х-Х|=2|у-Y|=1

  3. (х,у)=(Х,Y)

  4. Ми або перезапустимо на кроці 2, або повернемо останній індекс, який було знайдено, якщо ми закінчили.


Node.js , 155 байт

n=>(g=(x,y)=>n--?g(Buffer('QHUbcdWJ').map(m=c=>g[i=4*((x+=c%6-2)*x>(y+=c%7-2)*y?x:y)**2,i-=(x>y||-1)*(i**.5+x+y)]|i>m||(H=x,V=y,m=i))|H,V,g[m]=1):m+1)(1,2)

Спробуйте в Інтернеті!


3

05AB1E , 53 байти

Xˆ0UF2D(Ÿ0KãʒÄ1¢}εX+}Dε·nàDtyÆ+yO·<.±*->}D¯KßDˆkèU}¯θ

32θн+1

Спробуйте в Інтернеті або перевірте ще кілька тестових випадків (час вичерпано для найбільших тестових випадків).

Пояснення:

Дивіться пояснення в моїй пов'язаної стезю Wildebeest відповіді . Єдиними модифікованими деталями є:

2D    # Get a list in the range [-2,2]: [-2,-1,0,1,2]

і кінцевий:

θ       # Only leave the last item of the list

EDIT: Портом підходу @Arnauld у своїй відповіді JavaScript (ES7) є (наразі):

05AB1E , 57 56 байт

0D‚DˆUF64D(ŸãΣ·nàDtyÆ+yO·<.±*->}©ʒX-Pn4Q}¯¡˜2£DˆU}®J¯Jk>θ

Спробуйте в Інтернеті або перевірте ще кілька тестових випадків (час вичерпано для найбільших тестових випадків).

Пояснення:

‚%                # Create a pair of zeros: [0,0]
                  # (by pairing the (implicit) input with itself,
                  #  and then using modulo (implicit) input)
  DˆU             # Set both variable `X` to this, and add it to the global_array
F                 # Loop the (implicit) input amount of times:
 64D            #  Create a list in the range [-64,64]
      ã           #  Create each possible pair of `x,y`-coordinates
       Σ·nàDtyÆ+yO·<.±*->}
                  #  Sort this list in a spiral
        ©         #  Save it in the register (without popping)
 ʒ      }         #  Filter the list of coordinates by:
  X-              #   Subtract the coordinate of variable `X`
    P             #   Take the product
     n            #   Take the square
      4Q          #   Check if its equal to 4
                  # Since 05AB1E cannot remove inner lists, we use a workaround:
         ¯¡       # Split this list on each coordinate in the global_array
           ˜      # Flatten the entire list
            2£    # Only leave the first two integers as `x,y`-coordinate
                  # (if 05AB1E could remove inner lists, this would've been `¯Kн` instead)
              DˆU # Replace variable `X` with this, and add it to the global_array
                # After the loop: push all coordinates sorted in a spiral from the register
  J               # Join each coordinate together to a string
   ¯J             # Push the global_array, and also join them together to a string
                  # (if 05AB1E could index inner lists, both `J` could have been removed)
     k            # Get the index of each item of the global_array in the spiral list
      >           # Increase the 0-indexed index by 1 to make it 1-based
       θ          # And only leave the last one (which is output implicitly)

Σ·nàDtyÆ+yO·<.±*->}х,у


Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.