Introdução
Considere uma lista não vazia L de números inteiros. Uma fatia de soma zero de L é uma subsequência contígua de L cuja soma é igual a 0. Por exemplo, [1, -3, 2] é uma fatia de soma zero de [-2, 4, 1, -3, 2, 2 , -1, -1] , mas [2, 2] não é (porque não soma 0), e nem [4, -3, -1] (porque não é contíguo).
Uma coleção de fatias de soma zero de L é uma cobertura de soma zero de L se cada elemento pertencer a pelo menos uma das fatias. Por exemplo:
L = [-2, 4, 1, -3, 2, 2, -1, -1]
A = [-2, 4, 1, -3]
B = [1, -3, 2]
C = [2, -1, -1]
Os três fatias de soma zero Um , B e C formam uma tampa de soma-zero de L . Várias cópias da mesma fatia podem aparecer em uma capa de soma zero, assim:
L = [2, -1, -1, -1, 2, -1, -1]
A = [2, -1, -1]
B = [-1, -1, 2]
C = [2, -1, -1]
Obviamente, nem todas as listas têm uma cobertura de soma zero; alguns exemplos são [2, -1] (cada fatia tem soma diferente de zero) e [2, 2, -1, -1, 0, 1] (o 2 mais à esquerda não faz parte de uma fatia de soma zero).
A tarefa
Sua entrada é uma lista inteira não vazia L , tirada em qualquer formato razoável. Sua saída será um valor verdadeiro se L tiver uma cobertura de soma zero e um valor falso se não.
Você pode escrever um programa completo ou uma função, e a menor contagem de bytes vence.
Casos de teste
[-1] -> False
[2,-1] -> False
[2,2,-1,-1,0,1] -> False
[2,-2,1,2,-2,-2,4] -> False
[3,-5,-2,0,-3,-2,-1,-2,0,-2] -> False
[-2,6,3,-3,-3,-3,1,2,2,-2,-5,1] -> False
[5,-8,2,-1,-7,-4,4,1,-8,2,-1,-3,-3,-3,5,1] -> False
[-8,-8,4,1,3,10,9,-11,4,4,10,-2,-3,4,-10,-3,-5,0,6,9,7,-5,-3,-3] -> False
[10,8,6,-4,-2,-10,1,1,-5,-11,-3,4,11,6,-3,-4,-3,-9,-11,-12,-4,7,-10,-4] -> False
[0] -> True
[4,-2,-2] -> True
[2,2,-3,1,-2,3,1] -> True
[5,-3,-1,-2,1,5,-4] -> True
[2,-1,-1,-1,2,-1,-1] -> True
[-2,4,1,-3,2,2,-1,-1] -> True
[-4,-1,-1,6,3,6,-5,1,-5,-4,5,3] -> True
[-11,8,-2,-6,2,-12,5,3,-7,4,-7,7,12,-1,-1,6,-7,-4,-5,-12,9,5,6,-3] -> True
[4,-9,12,12,-11,-11,9,-4,8,5,-10,-6,2,-9,10,-11,-9,-2,8,4,-11,7,12,-5] -> True
[2,2,-1,-1,0,1] -> False
ser truthy vez que ambas as fatias [2,-1,-1]
e [-1,0,1]
adicione a zero e todos os seus elementos estão na lista original?