Giriş
En son çekilen The Trapped Knight - Numberphile videosundan esinlenerek bir meydan okuma buldum.
Tuzak Knight sekansı 1'den başlayarak uzunluğu 2016, sonlu bir tam sayı dizisi ve aşağıdaki yapı kuralları vardır:
- Bir sayı spiralini aşağıdaki şekilde yazın:
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 ...
- Üzerine bir şövalye koy 1.
- Şövalyeyi satranç kurallarına göre (yani 2 birim dikey ve 1 birim yatay veya tersi) daha önce ziyaret edilemeyen en küçük sayıya sahip ızgaraya taşıyın.
- Şövalye takılana kadar tekrarlayın.
İşte ilk üç adım:
Aşama 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
Olası hareketler 10, 12, 14, 16, 18, 20, 22, 24'tür, aralarında en küçük 10'dur, bu nedenle ikinci terim 10'dur.
Adım 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
Olası hamleler 1 , 3, 23, 29, 47, 49, 51, 53'tür, aralarında en küçük olanı 3'tür, bu nedenle üçüncü terim 3'tür.
Aşama 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
Olası hamleler 6, 8, 10 , 16, 28, 30, 32, 34'tür, aralarında en küçük 6'dır, bu nedenle dördüncü terim 6'dır.
Dizinin yıldızı:
1 10 3 6 9 4 7 2 5 8 11 14 ...
ile biter
... 2099 2284 2477 2096 2281 2474 2675 2884 3101 2880 2467 2084
Meydan okuma
En kısa program veya işlevi yazın, aralık olarak bir tamsayı [1, 2016]
(veya [0, 2015]
0 dizinli kullanılıyorsa) girdi olarak yazın, yakalanan şövalye dizisinde bu dizindeki sayıyı çıkarın. Diziyi 0 dizinli veya 1 dizinli olarak dizine eklemeyi seçebilirsiniz, ancak hangi dizinleme düzenini kullandığınızı belirtmeniz gerekir.
Test senaryoları (1 endeksli)
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
Tüm olası çıktılar için lütfen bu sayfaya bakın .
Kazanma Kriterleri
Her dilin en kısa kodu kazanır. Standart boşluklarda kısıtlamalar geçerlidir.
12851850258