fundo
Manipuladores de cartas muito hábeis são capazes de uma técnica pela qual cortam um baralho perfeitamente ao meio e depois intercalam perfeitamente os cartões. Se eles começarem com um deck classificado e executarem essa técnica sem falhas 52 vezes seguidas, o deck será restaurado na ordem classificada. Seu desafio é pegar um baralho de cartas em uma matriz inteira e determinar se ele pode ser classificado usando apenas shuffles de Faro.
Definição
Matematicamente, um shuffle de Faro é uma permutação em 2 n elementos (para qualquer número inteiro positivo n ) que leva o elemento na posição i (indexada 1) para a posição 2 i (mod 2 n +1). Também gostaríamos de poder lidar com listas de tamanhos ímpares, portanto, nesse caso, basta adicionar um elemento ao final da lista (um Coringa, se você tiver uma disponível) e Faro embaralhar a nova lista como acima, mas ignore o elemento fictício adicionado ao verificar a ordem da lista.
Objetivo
Escreva um programa ou função que pegue uma lista de números inteiros e retorne ou produza uma verdade se algum número de embarques de Faro fizer com que a lista seja classificada em ordem não descendente (mesmo que esse número seja zero - listas pequenas devem dar uma verdade). Caso contrário, retorne ou produza um falso.
Exemplos
[1,1,2,3,5,8,13,21] => True
[5,1,8,1,13,2,21,3] => True
[9,36,5,34,2,10,1] => True
[1,0] => True
[0] => True
[] => True
[3,2,1] => True
[3,1,2] => False
[9,8,7,6,5,4,3,2,1,0] => True
[9,8,7,6,5,4,3,2,0,1] => False
[3,1,4,1,5,9,2,6,9] => False
[-1,-1,-1,-2] => True
Pontuação
Este é o código-golfe, e a fonte mais curta em bytes vence.
fonte
Respostas:
Pitão -
262524 bytesUtiliza redução cumulativa para aplicar o shuffle de Faro várias vezes e manter todos os resultados. Em seguida, ele mapeia através dele e verifica se eles são invariantes na classificação e, em seguida, usa sum para verificar se são verdadeiros. Retorna um positivo ou zero.
Conjunto de Teste .
fonte
MATL , 41 bytes
A saída é
1
ou0
.Explicação
Exemplo
fonte