首頁 >後端開發 >C++ >如何在 C 中實作返回迭代器的二分查找演算法?

如何在 C 中實作返回迭代器的二分查找演算法?

Linda Hamilton
Linda Hamilton原創
2024-10-24 04:49:02607瀏覽

How to Implement a Binary Search Algorithm That Returns an Iterator in C  ?

C 中的二分查找演算法回傳迭代器

在C 中,std::binary_search 演算法提供了一種便捷的方法對已排序的容器執行二分搜尋。然而,它只傳回一個布林值來指示元素是否存在,這對於某些應用程式來說可能不夠。

迭代器傳回演算法的要求

需要出現一個二分搜尋演算法,傳回指向結果的迭代器而不是布林值。這允許開發人員存取找到的實際元素或確定它是否不存在於容器中。

實現自訂二分搜尋演算法

因為沒有這樣的函數標準庫中提供了自訂實現,可以使用其他STL 函數來製作自訂實現,例如std::lower_boundstd::upper_boundstd::equal_range .

範例實作

範例實作範例。

這是一個使用
<code class="cpp">template<class Iter, class T>
Iter binary_find(Iter begin, Iter end, T val)
{
    // Finds the lower bound in at most log(last - first) + 1 comparisons
    Iter i = std::lower_bound(begin, end, val);

    if (i != end &amp;&amp; !(val < *i))
        return i; // found
    else
        return end; // not found
}</code>
std::lower_bound

:

或者,使用std::set

另一種選擇是使用std::set,它維護排序元素並提供方法find(T key),該方法傳回指定項目的迭代器。但是,如果容器中需要同一元素的多個實例,則此方法可能不合適。

以上是如何在 C 中實作返回迭代器的二分查找演算法?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn