[解決済み] Pythonによる二項探索(バイセクショ ン)機能
質問
リスト/タプルに対してバイナリサーチを行い、見つかった場合はその項目の位置を、見つからなかった場合は「False」(-1、Noneなど)を返すライブラリ関数はないでしょうか?
の中にbisect_left/rightという関数がありました。 bisectモジュール しかし、それらは項目がリストにない場合でも位置を返します。しかし、私はアイテムがリストにあるかどうかを知りたいだけです(何も挿入したくないのです)。
を使うことを考えました。
bisect_left
しかし、それは面倒なようです(さらに、その数字がリストの中で最大の数字より大きくなりうるかどうか境界チェックを行う必要があります)。もっといい方法があれば教えて欲しいです。
編集 何のためにこれが必要なのかを明確にするために。辞書が非常に適していることは承知していますが、メモリ消費量をできるだけ抑えたいのです。私の意図する使い方は、双方向ルックアップテーブルのようなものです。テーブルには値のリストがあり、そのインデックスに基づいて値にアクセスできる必要があります。また、特定の値のインデックスを見つけるか、その値がリストにない場合は None にしたいのです。
このために辞書を使用するのが最も速い方法ですが、必要なメモリが(およそ)2倍になってしまいます。
Pythonのライブラリに何か見落としがあるのではないかと思い、質問させていただきました。Moeが提案したように、自分でコードを書くしかないようです。
どのように解決するのですか?
bisect_left
最初の位置を見つける
p
は、ソートされた順序を維持したまま、与えられたソート範囲に要素を挿入することができます。 の位置となります。
x
もし
x
が範囲内に存在する。もし
p
は過去の終了位置です。
x
は見つかりませんでした。 そうでなければ
x
があるかどうかを確認するために
x
が見つかりました。
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
関連
-
Python関数の高度な応用を解説
-
pythonサイクルタスクスケジューリングツール スケジュール詳解
-
[解決済み】 AttributeError("'str' object has no attribute 'read'")
-
[解決済み] Pythonには文字列の'contains'サブストリングメソッドがありますか?
-
[解決済み] Pythonで現在時刻を取得する方法
-
[解決済み] Pythonで2つのリストを連結する方法は?
-
[解決済み] ファイルのコピー方法について教えてください。
-
[解決済み] Pythonで例外を手動で発生(スロー)させる
-
[解決済み】ネストされたディレクトリを安全に作成するには?
-
[解決済み】Pythonに三項条件演算子はありますか?
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
Python interpreted model libraryによる機械学習モデル出力の可視化 Shap
-
パッケージングツールPyinstallerの使用と落とし穴の回避
-
Python LeNetネットワークの説明とpytorchでの実装
-
[解決済み】ilocが「IndexError: single positional indexer is out-of-bounds」を出す。
-
[解決済み】ImportError: PILという名前のモジュールがない
-
[解決済み】syntaxError: 'continue' がループ内で適切に使用されていない
-
[解決済み】Python elifの構文が無効です【終了しました
-
[解決済み】LogisticRegression: Pythonでsklearnを使用して、未知のラベルタイプ: '連続'を使用しています。
-
[解決済み】「OverflowError: Python int too large to convert to C long" on windows but not mac
-
[解決済み] リストに値が存在するかどうかを確認する最速の方法