Latar Belakang
Sebuah mantan peningkatan set urutan urutan didefinisikan sebagai urutan bilangan bulat set yang memenuhi berikut:S 1 , S 2 , ⋯ , S n
- Setiap adalah bagian yang tidak kosong dari . { 1 , 2 , ⋯ , N }
- Untuk , , yaitu setiap dua set berturut-turut tidak memiliki elemen yang sama.S i ∩ S i + 1 = ∅
- Untuk , rata-rata (nilai rata-rata) benar-benar kurang dari .S i S i + 1
Tantangan
Diberikan bilangan bulat positif N, menampilkan panjang urutan urutan peningkatan terlama yang terlama N.
Uji kasus
Ini didasarkan pada hasil oleh Project Euler pengguna thundre .
1 => 1 // {1}
2 => 2 // {1} {2}
3 => 3 // {1} {2} {3}
4 => 5 // {1} {2} {1,4} {3} {4}
5 => 7 // {1} {2} {1,4} {3} {2,5} {4} {5}
6 => 10 // {1} {2} {1,4} {3} {1,4,5} {2,3,6} {4} {3,6} {5} {6}
7 => 15 // {1} {2} {1,4} {3} {1,2,7} {3,4} {1,2,5,7} {4} {1,3,6,7} {4,5} {1,6,7} {5} {4,7} {6} {7}
8 => 21
9 => 29
10 => 39
11 => 49
12 => 63
13 => 79
14 => 99
15 => 121
16 => 145
17 => 171
18 => 203
19 => 237
20 => 277
21 => 321
22 => 369
23 => 419
24 => 477
25 => 537
Aturan
Aturan standar kode-golf berlaku. Pengajuan terpendek yang valid dalam byte menang.
Karunia
Masalah ini telah dibahas di sini di forum Project Euler sekitar 4 tahun yang lalu, tetapi kami gagal menghasilkan algoritma waktu polinomial yang dapat dibuktikan (dalam hal N). Oleh karena itu, saya akan memberikan hadiah +200 kepada kiriman pertama yang mencapai ini, atau membuktikan ketidakmungkinannya.