Heim >Backend-Entwicklung >Python-Tutorial >Wie kann das Vorhandensein von Unterlisten in einer Python-Liste effizient bestimmt werden?

Wie kann das Vorhandensein von Unterlisten in einer Python-Liste effizient bestimmt werden?

Linda Hamilton
Linda HamiltonOriginal
2024-10-26 18:01:03369Durchsuche

How to Efficiently Determine Sublist Presence in a Python List?

Bestimmen des Vorhandenseins einer Unterliste in einer Python-Liste

Um zu überprüfen, ob eine Unterliste in einer größeren Liste vorhanden ist, kann man die Leistungsfähigkeit der funktionalen Programmierung nutzen in Python. Hier ist eine prägnante Funktion, die dies erreicht:

<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>

Die Funktion iteriert durch die größere Liste lst, beginnend bei Index i, und vergleicht einen Abschnitt der Länge n (die Länge der Unterliste) mit der Unterliste sublst. Wenn eines dieser Slices mit sublst übereinstimmt, gibt die Funktion True zurück. Andernfalls wird False zurückgegeben.

Betrachten Sie die folgenden Beispiele:

<code class="python">lst1 = [1,0,1,1,1,0,0]
lst2 = [1,0,1,0,1,0,1]

sublistExists(lst1, [1,1,1]) == True
sublistExists(lst2, [1,1,1]) == False</code>

Die Funktion arbeitet mit O(m*n) Zeitkomplexität, wobei m die Länge der größeren Liste und n die Länge der größeren Liste ist ist die Länge der Unterliste. Es nutzt die Funktion „any()“, um beim ersten Treffer effizient zu beenden und so die Recheneffizienz sicherzustellen.

Das obige ist der detaillierte Inhalt vonWie kann das Vorhandensein von Unterlisten in einer Python-Liste effizient bestimmt werden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn