Geléia , 7 6 bytes (fácil)
IAṢ⁼J$
Experimente online!
IAṢ⁼J$ jolly function on N:
IAṢ the increment list: get all the Increments, take their Absolute values, and Ṣort them
⁼ compare that to...
J$ range from 1 to len(N) -- this has an extra number, but that's fine because...
...the increment list is one shorter, and ⁼ will only compare that many values
Recebe entrada como números separados por vírgula no primeiro argumento. Retorna 1 se a sequência for alegre e 0 se não for!
Solução de 7 bytes:
LRṖḟIA$
Experimente online!
Recebe entrada como números separados por vírgula no primeiro argumento. Não retorna nada se a lista for uma sequência de jumper alegre e algo se não for.
A adição desta linha faz com que ela funcione com as especificações rígidas:
Geléia , 27 22 bytes (muito, feedback bem-vindo!)
ɠḲVIAṢ⁼J$ị“¢⁼D“¡KṀȥƘạ»
Experimente online!
ɠḲVIAṢ⁼J$ị“¢⁼D“¡KṀȥƘạ»
ɠḲV read a line, split on spaces and eValuate the numbers
IAṢ⁼J$ jolly function: see above!
ị ịndex the result into (remember Jelly is one-indexed, so 0 wraps around to the back):
“¢⁼D“ "Jolly" compressed if true,
¡KṀȥƘạ» or, "Not jolly" compressed if false!
Solução de 27 bytes (difícil):
LRṖḟIA$
ɠḲVÇ“¡KṀȥƘạ»“¢⁼D»L?
Experimente online!
Coloca em números separados por espaço stdin
e gera "Jolly" ou "Not jolly".
Explicação:
LRṖḟIA$ jolly function:
LRP make a range (R) from 1 to the input length (L), popping off (P) the last number to make it 1 to N-1.
ḟ reverse filter: remove all the elements from that range that are members of...
IA$ the increment list: get all the increments, take their absolute values (expressed as one monad via '$').
ɠḲVÇ“¡KṀȥƘạ»“¢⁼D»L? i/o main function:
ɠḲV read a line from stdin, split it on spaces and have Python parse each number (handling negative signs)
Ç ? run the above, and use the result on the following conditional:
L? if the length of the result is truthy (non-empty):
“¡KṀȥƘạ» then, return Jelly compressed string "Not jolly",
“¢⁼D» else, return Jelly compressed string "Jolly".
Qualquer feedback muito apreciado!