Selama beberapa hari terakhir, saya telah mempelajari pertanyaan berikut di StackExchange tentang spiral bilangan bulat. Kami mencari rumus tertutup untuk koordinat elemen ke- \(n\) dalam spiral bilangan bulat berikut, yang memanjang dari awal ke luar dan lebih jauh dan lebih jauh ke tak terhingga:
.. 9 10 11 12
23 8 1 2 13
22 7 0 3 14
21 6 5 4 15
20 19 18 17 16
Pertama kita membagi bilangan asli menjadi kelompok-kelompok berikut:
$$G_1 = \{ 1,...,8 \}\\G_2 = \{ 9, ..., 24 \}\\G_3 = \{ 25, ... 48 \}\\...\\G_k = \left\{ (2k-1)^2, (2k+1)^2 - 1 \right\}$$
Kami memanggil
$$a^2 = \left(\left \lfloor \left( \frac{\left \lfloor \sqrt{n} \right \rfloor + 1}{2} \right) \right \rfloor \cdot 2 - 1 \right)^2$$
nomor awal dalam sebuah kelompok.
Dalam sebuah grup ada empat subgrup dengan ukuran yang sama \(G_1\) untuk \(G_1\) adalah \(g_1 = \{ 1,2 \}, g_2 = \{ 3,4 \}, g_3 = \{ 5,6 \}, g_4 = \{7,8\}\) ). Jika \(n\) dari satu subgrup ke subgrup berikutnya, arah pada jalur spiral (searah jarum jam dalam contoh kita) juga berubah pada waktu yang sama. Kami mendapatkan arah saat ini \( b \in \{0,1,2,3\} \) dengan membagi posisi \(na^2\) dalam grup dengan jumlah elemen dalam subkelompok:
$$b = \left \lfloor \frac{ n - a^2 }{ \text{abs}\left( a \right) + 1 } \right \rfloor$$
Sekarang kita dapat menentukan elemen pertama dalam subgrup \(g_n\) dengan menambahkan beberapa \(b\) dari nomor \(a+1\) elemen dalam grup ke nomor awal \(a^2\):
$$c = a^2 + b \cdot (a+1)$$
Sekarang kita bisa menentukan dengan observasi sederhana:
$$x_{right} = \left(n - c - \frac{ a + 1 }{2}+1\right),\, y_{right} = \left(\frac{ a + 1 }{2}\right) \\ x_{bottom} = \left(\frac{ a + 1 }{2}\right),\, y_{bottom} = (-1) \cdot \left( n - c - \frac{ a + 1 }{2}+1\right) \\ x_{left} = (-1) \cdot \left(n - c - \frac{ a + 1 }{2}+1\right),\, y_{left} = (-1) \cdot \left(\frac{ a + 1 }{2}\right) \\ x_{top} = (-1) \cdot \left(\frac{ a + 1 }{2}\right),\, y_{top} = \left( n - c - \frac{ a + 1 }{2}+1\right)$$
Kami ingin merepresentasikan \(f(n)\) dalam representasi tertutup dan juga tanpa perbedaan kasus. Kami menggunakan fungsi Signum, saya telah menjelaskan prosedurnya di sini . Sehingga kita mendapatkan rumus murni sebagai fungsi dari \(n\) , kita dapatkan:
Dengan bantuan SVG.js , kita dapat melihat dalam visualisasi kecil ini bahwa semuanya benar-benar berfungsi:
See the Pen ulam spiral by David Vielhuber (@vielhuber) on CodePen.
Spiral ini juga dikenal sebagai spiral Ulam dan memiliki hubungan yang menarik dengan bilangan prima.