首頁 > 後端開發 > C++ > 如何在 C 中實現返回元素位置的二分查找演算法?

如何在 C 中實現返回元素位置的二分查找演算法?

DDD
發布: 2024-10-24 03:49:31
原創
993 人瀏覽過

How to Implement a Binary Search Algorithm in C   That Returns the Element's Location?

獲得一個「有用的」C 二分搜尋演算法

C STL 提供了一個binary_search 演算法,但它只傳回一個布林值,指示是否元素存在。對於需要元素的確切位置的情況,需要更全面的演算法。

一個選項是建立自訂二分搜尋函數。這是一個簡單的實作:

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

    if (i != end && !(val < *i))
        return i; // found
    else
        return end; // not found
}</code>
登入後複製

另一種方法是使用std::set,它會自動對元素進行排序並提供一個find(T key) 方法,該方法傳回項目的迭代器。但是,如果資料可能包含重複值,這可能不合適。

對於速度至關重要的情況,利用二分搜尋的優勢非常重要。當元素不存在時,lower_bound 和 upper_bound 演算法可能不夠用,因為它們可能不會傳回結束迭代器。上面提供的binary_find函數解決了這個問題並確保了正確的行為。

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

來源:php
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板