introduzione
Considera un elenco non vuoto L di numeri interi. Una sezione di somma zero di L è una sottosequenza contigua di L la cui somma è uguale a 0. Ad esempio, [1, -3, 2] è una sezione di somma zero di [-2, 4, 1, -3, 2, 2 , -1, -1] , ma [2, 2] non lo è (perché non si somma a 0) e nemmeno [4, -3, -1] (perché non è contiguo).
Una raccolta di sezioni a somma zero di L è una copertura a somma zero di L se ogni elemento appartiene ad almeno una delle sezioni. Per esempio:
L = [-2, 4, 1, -3, 2, 2, -1, -1]
A = [-2, 4, 1, -3]
B = [1, -3, 2]
C = [2, -1, -1]
I tre somma zero affetta A , B e C formano una copertura somma zero L . Più copie della stessa sezione possono apparire in una copertina a somma zero, in questo modo:
L = [2, -1, -1, -1, 2, -1, -1]
A = [2, -1, -1]
B = [-1, -1, 2]
C = [2, -1, -1]
Naturalmente, non tutte le liste hanno una copertura a somma zero; alcuni esempi sono [2, -1] (ogni slice ha una somma diversa da zero) e [2, 2, -1, -1, 0, 1] (il 2 più a sinistra non fa parte di una slice a somma zero).
L'obiettivo
Il tuo input è un elenco intero non vuoto L , preso in qualsiasi formato ragionevole. Il risultato deve essere un valore veritiero se L ha una copertura a somma zero e un valore falso in caso contrario.
È possibile scrivere un programma completo o una funzione e vince il conteggio dei byte più basso.
Casi test
[-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
essere vero dal momento che entrambe le sezioni [2,-1,-1]
e si [-1,0,1]
aggiungono a zero e tutti i loro elementi sono nell'elenco originale?