ホームページ バックエンド開発 Python チュートリアル Python でサブリストが存在するかどうかを効率的に判断するにはどうすればよいですか?

Python でサブリストが存在するかどうかを効率的に判断するにはどうすればよいですか?

Oct 26, 2024 pm 09:55 PM

 How to Efficiently Determine if a Sublist Exists in Python?

Python でのサブリストの存在の検出

当面の課題は、より大きなリスト内のサブリストの存在を検証する関数を考案することです。 2 つのリスト、1 つは大きなリスト (list1) として、もう 1 つは潜在的なサブリスト (list2) として与えられると、関数は list2 が実際に list1 のサブリストであるかどうかを判断する必要があります。

関数の実装

Python には、この目的に利用できる any() という多用途の関数が用意されています。次のコード スニペットは、any() を使用する関数を構築する方法を示しています。

<code class="python">def sublist_exists(lst, sublst):
    n = len(sublst)
    return any((sublst == lst[i:i+n]) for i in range(len(lst)-n+1))</code>
ログイン後にコピー

この関数は、要素を 1 つずつ反復処理することで、より大きなリスト (lst) を注意深くスキャンします。インデックス i の要素ごとに、長さ n の連続したサブリストを抽出し、それを潜在的なサブリスト (sublst) と比較します。一致が検出された場合、関数はすぐに True を返し、サブリストの存在を示します。このプロセスは、一致するものが見つかるか、より大きなリスト全体が使い尽くされるまで続きます。その場合、関数は False を返します。

パフォーマンスに関する考慮事項

注意することが重要です。この関数の時間計算量は O(m*n) であることがわかります。ここで、m は大きい方のリストの長さ、n は潜在的なサブリストの長さです。反復ごとに、関数はサブリスト比較演算を実行し、反復回数は m と n の差に 1 を加えたものによって制限されます。

使用例

見てみましょう提供された例で sublist_exists 関数の使用法を示します。

<code class="python">>>> sublist_exists([1,0,1,1,1,0,0], [1,1,1])
True

>>> sublist_exists([1,0,1,0,1,0,1], [1,1,1])
False</code>
ログイン後にコピー

最初の例では、[1,1,1] は確かに大きなリストのサブリストであるため、関数は True を返します。 2 番目の例では、[1,1,1] が大きいリストに表示されないため、関数は False を返します。

以上がPython でサブリストが存在するかどうかを効率的に判断するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Pythonを使用してテキストファイルのZIPF配布を見つける方法 Pythonを使用してテキストファイルのZIPF配布を見つける方法 Mar 05, 2025 am 09:58 AM

Pythonを使用してテキストファイルのZIPF配布を見つける方法

Pythonでファイルをダウンロードする方法 Pythonでファイルをダウンロードする方法 Mar 01, 2025 am 10:03 AM

Pythonでファイルをダウンロードする方法

Pythonでの画像フィルタリング Pythonでの画像フィルタリング Mar 03, 2025 am 09:44 AM

Pythonでの画像フィルタリング

HTMLを解析するために美しいスープを使用するにはどうすればよいですか? HTMLを解析するために美しいスープを使用するにはどうすればよいですか? Mar 10, 2025 pm 06:54 PM

HTMLを解析するために美しいスープを使用するにはどうすればよいですか?

Pythonを使用してPDFドキュメントの操作方法 Pythonを使用してPDFドキュメントの操作方法 Mar 02, 2025 am 09:54 AM

Pythonを使用してPDFドキュメントの操作方法

DjangoアプリケーションでRedisを使用してキャッシュする方法 DjangoアプリケーションでRedisを使用してキャッシュする方法 Mar 02, 2025 am 10:10 AM

DjangoアプリケーションでRedisを使用してキャッシュする方法

Natural Language Toolkit(NLTK)の紹介 Natural Language Toolkit(NLTK)の紹介 Mar 01, 2025 am 10:05 AM

Natural Language Toolkit(NLTK)の紹介

TensorflowまたはPytorchで深い学習を実行する方法は? TensorflowまたはPytorchで深い学習を実行する方法は? Mar 10, 2025 pm 06:52 PM

TensorflowまたはPytorchで深い学習を実行する方法は?

See all articles