項目の存在を確認するために Python で二分検索を効率的に実装するにはどうすればよいですか?
Python の二分検索 (ハロー検索)
Python は、二分検索 (二分検索とも呼ばれます) を実装するためのライブラリ関数を提供します。ソートされたリストまたはタプル内の項目。ただし、項目が見つからない場合でも、これらの関数は位置を返します。
この問題を解決し、項目が存在するかどうかのみを検出するには、bisect.bisect_left() 関数を使用して挿入位置を見つけ、その位置にある項目がターゲット項目と等しいかどうかを確認する方法があります。 。ただし、これは面倒な場合があり、数値がリスト内の最大の数値よりも大きい場合には境界チェックも必要になります。
メモリを消費するため、質問では代替として辞書が提案されています。ただし、これには約 2 倍のメモリ要件が必要になる場合があります。
したがって、この問題は、カスタム コードを使用して二分探索を実装することで解決できます。
from bisect import bisect_left def binary_search(a, x, lo=0, hi=None): if hi is None: hi = len(a) pos = bisect_left(a, x, lo, hi) # find insertion position return pos if pos != hi and a[pos] == x else -1 # don't walk off the end
この関数は、bisect_left() 関数を使用して挿入位置を見つけます。ターゲット項目が存在する場合はその項目を指定し、存在しない場合は範囲外の位置を指定します。対象の項目が存在するかどうかは、その位置の項目が対象の項目と等しいかどうかで判断できます。
以上が項目の存在を確認するために Python で二分検索を効率的に実装するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

ホットトピック









LinuxターミナルでPythonバージョンを表示する際の許可の問題の解決策PythonターミナルでPythonバージョンを表示しようとするとき、Pythonを入力してください...

10時間以内にコンピューター初心者プログラミングの基本を教える方法は?コンピューター初心者にプログラミングの知識を教えるのに10時間しかない場合、何を教えることを選びますか...

PythonのPandasライブラリを使用する場合、異なる構造を持つ2つのデータフレーム間で列全体をコピーする方法は一般的な問題です。 2つのデータがあるとします...

fiddlereveryversings for the-middleの測定値を使用するときに検出されないようにする方法

正規表現は、プログラミングにおけるパターンマッチングとテキスト操作のための強力なツールであり、さまざまなアプリケーションにわたるテキスト処理の効率を高めます。

UvicornはどのようにしてHTTPリクエストを継続的に聞きますか? Uvicornは、ASGIに基づく軽量のWebサーバーです。そのコア機能の1つは、HTTPリクエストを聞いて続行することです...

この記事では、numpy、pandas、matplotlib、scikit-learn、tensorflow、django、flask、and requestsなどの人気のあるPythonライブラリについて説明し、科学的コンピューティング、データ分析、視覚化、機械学習、Web開発、Hの使用について説明します。

Pythonでは、文字列を介してオブジェクトを動的に作成し、そのメソッドを呼び出す方法は?これは一般的なプログラミング要件です。特に構成または実行する必要がある場合は...
