fundo
Uma sequência de conjuntos ex-crescente da ordem é definida como uma sequência de conjuntos inteiros que satisfaz o seguinte:S 1 , S 2 , ⋯ , S n
- Cada é um subconjunto não vazio de . { 1 , 2 , ⋯ , N }
- Para , , ou seja, quaisquer dois conjuntos consecutivos não têm elementos em comum.S i ∩ S i + 1 = ∅
- Para , a média (valor médio) de é estritamente menor que a de .S i S i + 1
Desafio
Dado um número inteiro positivo N
, produza o comprimento da sequência de ordem mais longa ex-crescente N
.
Casos de teste
Estes são baseados nos resultados por usuário do Project Euler 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
Regras
Aplicam-se as regras de código-golfe padrão . O menor envio válido em bytes vence.
Recompensa
Esse problema foi discutido aqui no fórum do Project Euler há cerca de 4 anos, mas não conseguimos criar um algoritmo de tempo polinomial comprovável (em termos de N
). Portanto, concederei +200 de recompensa à primeira submissão que conseguir isso ou provar sua impossibilidade.