>백엔드 개발 >C++ >요소의 위치를 ​​반환하는 C에서 이진 검색 알고리즘을 구현하는 방법은 무엇입니까?

요소의 위치를 ​​반환하는 C에서 이진 검색 알고리즘을 구현하는 방법은 무엇입니까?

DDD
DDD원래의
2024-10-24 03:49:31993검색

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

"유용한" C 바이너리 검색 알고리즘 얻기

C STL은 바이너리 검색 알고리즘을 제공하지만, 요소가 존재합니다. 요소의 정확한 위치가 필요한 경우에는 보다 포괄적인 알고리즘이 필요합니다.

한 가지 옵션은 사용자 정의 이진 검색 기능을 만드는 것입니다. 다음은 간단한 구현입니다.

<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>

또 다른 접근 방식은 요소를 자동으로 정렬하고 항목에 대한 반복자를 반환하는 find(T 키) 메서드를 제공하는 std::set를 사용하는 것입니다. 그러나 데이터에 중복된 값이 포함될 수 있는 경우에는 적합하지 않을 수 있습니다.

속도가 중요한 상황에서는 이진 검색의 이점을 활용하는 것이 중요합니다. Lower_bound 및 upper_bound 알고리즘은 요소가 존재하지 않는 경우 최종 반복자를 반환하지 않을 수 있으므로 부적절할 수 있습니다. 위에 제공된 bin_find 함수는 이 문제를 해결하고 올바른 동작을 보장합니다.

위 내용은 요소의 위치를 ​​반환하는 C에서 이진 검색 알고리즘을 구현하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.