Maison >développement back-end >Tutoriel Python >Comment pouvez-vous déterminer efficacement la présence d'une sous-liste dans une liste plus grande en Python ?

Comment pouvez-vous déterminer efficacement la présence d'une sous-liste dans une liste plus grande en Python ?

Patricia Arquette
Patricia Arquetteoriginal
2024-10-26 22:33:31515parcourir

How Can You Efficiently Determine Sublist Presence Within a Larger List in Python?

Recherche dans des listes de la présence d'une sous-liste en Python

Identifier la présence d'une sous-liste dans une liste plus grande est une tâche de programmation courante. Python propose une solution simple à ce problème à l'aide d'une fonction personnalisée.

Formulation du problème :

Étant donné deux listes, list1 et list2, déterminez si les éléments de list2 existent comme une séquence contiguë dans list1. Considérez les cas de test suivants :

<code class="python">list1 = [1,0,1,1,1,0,0]
list2 = [1,0,1,0,1,0,1]

# Should return True
sublistExists(list1, [1,1,1])

# Should return False
sublistExists(list2, [1,1,1])</code>

Implémentation :

Les capacités de programmation fonctionnelle de Python permettent une solution concise utilisant la fonction any() et les compréhensions de liste :

<code class="python">def contains_sublist(lst, sublst):
    n = len(sublst)
    return any((sublst == lst[i:i+n]) for i in range(len(lst)-n+1))</code>

Cette fonction prend deux arguments : lst (la liste principale) et sublst (la sous-liste à rechercher). Il calcule la longueur de sublst et utilise une compréhension de liste pour générer une séquence de plages d'index dans lst. Pour chaque plage, il compare sublst aux éléments correspondants dans lst. Si une correspondance est trouvée, any() renvoie True ; sinon, il renvoie False.

Exemple d'utilisation :

Dans les cas de test fournis, sublistExists(list1, [1,1,1]) renvoie True et sublistExists( list2, [1,1,1]) renvoie False, comme prévu.

Remarque :

La fonction any() optimise la recherche en se terminant à la première correspondance . La fonction a une complexité temporelle de O(m*n), où m est la longueur de lst et n est la longueur de sublst.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn