「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > 検索結果に反復子を返す効率的なバイナリ検索アルゴリズムを C++ で実装できますか?

検索結果に反復子を返す効率的なバイナリ検索アルゴリズムを C++ で実装できますか?

2024 年 11 月 8 日に公開
ブラウズ:194

Can You Implement an Efficient Binary Search Algorithm in C   that Returns an Iterator to the Search Result?

C での効率的な二分探索アルゴリズムの検索

プログラマーは、対数時間計算量の利点を提供する効率的な二分探索アルゴリズムの実装を求めることがよくあります。 。一般的な要件の 1 つは、アルゴリズムが検索結果の存在を示す単純なブール値ではなく、検索結果を指す反復子を返すことです。

C 標準ライブラリでは ヘッダーで std::binary_search が提供されていますが、それは単にブール値を返します。質問者が指摘したように、バイナリ検索の速度が望まれ、データが並べ替えられることがわかっている状況では、これはイライラする可能性があります。

幸いなことに、必要な機能を提供する利用可能な代替実装があります。一般的なオプションの 1 つは、std:: lower_bound、std::upper_bound、または std::equal_range 関数を利用するカスタム アルゴリズムを使用することです。このような実装の簡略版は次のとおりです:

template
Iter binary_find(Iter begin, Iter end, T val) {
    // Determine the lower bound using binary search
    Iter i = std::lower_bound(begin, end, val);

    // If the element is found, return the iterator to it
    if (i != end && !(val 

代わりに、要素の順序を保証し、目的の項目への反復子を返す find メソッドを提供する std::set を使用することもできます。ただし、特に同じ要素の複数のインスタンスを保存する必要がある場合、要件がセットの使用と互換性があるかどうかを考慮することが重要です。

リリースステートメント この記事は次の場所に転載されています: 1729693891 侵害がある場合は、[email protected] に連絡して削除してください。
最新のチュートリアル もっと>

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3