>백엔드 개발 >C++ >C++에서 보간 검색 알고리즘을 사용하는 방법

C++에서 보간 검색 알고리즘을 사용하는 방법

王林
王林원래의
2023-09-19 09:21:091129검색

C++에서 보간 검색 알고리즘을 사용하는 방법

C++에서 보간 검색 알고리즘을 사용하는 방법

소개:
많은 응용 프로그램에서 정렬된 배열이나 정렬된 데이터 컬렉션에서 특정 요소를 검색하고 찾아야 하는 경우가 많습니다. 전통적인 이진 검색 알고리즘은 가장 일반적으로 사용되는 방법 중 하나이지만 경우에 따라 충분히 효율적이지 않을 수 있습니다. 보간 검색 알고리즘은 알려진 데이터의 분포를 기반으로 대상 요소를 더 빠르게 찾을 수 있는 향상된 검색 알고리즘입니다. 이 기사에서는 보간 검색 알고리즘이 무엇인지, C++에서 이를 사용하는 방법을 소개하고 코드 예제를 제공합니다.

  1. 보간 검색 알고리즘 개요
    보간 검색 알고리즘은 정렬된 배열이나 정렬된 데이터 세트에서 대상 요소의 추정 위치를 기반으로 검색하는 알고리즘입니다. 보간 검색 알고리즘은 기존 이진 검색 알고리즘과 달리 데이터 모음 내 대상 요소의 분포를 기반으로 추정하여 대상 요소를 더 빠르게 찾습니다. 선형 보간을 사용하여 대상 요소의 위치를 ​​예측하고 해당 위치를 기반으로 검색 범위를 결정합니다. 보간 탐색 알고리즘의 단계는 다음과 같습니다.
  • 데이터 세트에서 대상 요소의 추정 위치 계산: 대상 요소의 값과 데이터의 최소값, 최대값을 기반으로 추정 위치를 계산합니다. 설정 및 배열 길이.
  • 검색 범위 결정: 예상 위치를 기준으로 검색 범위를 결정합니다. 추정된 위치가 대상 요소보다 작은 경우 검색 범위는 추정된 위치에서 데이터 세트의 끝까지이고, 그렇지 않은 경우에는 데이터 세트의 시작부터 추정된 위치까지입니다.
  • 검색 범위 내 이진 검색: 기존 이진 검색 알고리즘을 사용하여 검색 범위 내에서 대상 요소를 찾습니다.
  1. C++에서 보간 검색 알고리즘 구현
    이제 C++에서 보간 검색 알고리즘을 사용하는 방법을 살펴보겠습니다. 먼저, 정렬된 데이터 컬렉션을 제공하고 보간 검색 알고리즘의 기능을 구현해야 합니다. 다음은 간단한 C++ 샘플 코드입니다.
#include <iostream>
#include <vector>

// 插值搜索算法函数
int interpolationSearch(const std::vector<int>& arr, int target) {
    int low = 0;
    int high = arr.size() - 1;
    
    while (low <= high && target >= arr[low] && target <= arr[high]) {
        // 计算预估位置
        int pos = low + ((target - arr[low]) * (high - low)) / (arr[high] - arr[low]);
        
        if (arr[pos] == target) {
            return pos;
        }
        
        if (arr[pos] < target) {
            low = pos + 1;
        } else {
            high = pos - 1;
        }
    }
    
    return -1; // 没有找到目标元素
}
 
int main() {
    std::vector<int> arr = {1, 3, 5, 7, 9, 11, 13, 15};
    int target = 9;
    
    int result = interpolationSearch(arr, target);
    
    if (result != -1) {
        std::cout << "目标元素 " << target << " 的索引位置为 " << result << std::endl;
    } else {
        std::cout << "目标元素 " << target << " 未找到" << std::endl;
    }
    
    return 0;
}

위 코드에서는 먼저 보간 검색 알고리즘을 수행하기 위해 interpolationSearch的函数,它接受一个有序的整数向量arr和目标元素target作为参数。接下来,在函数中我们定义了两个指针lowhigh,它们表示搜索的范围。然后,我们使用一个循环来进行搜索,直到找到目标元素或搜索范围为空。在循环中,我们首先计算目标元素的预估位置pos,然后检查该位置上的元素是否是目标元素。如果是,我们返回该位置。否则,我们根据目标元素和预估位置的比较结果更新lowhigh指针的值,缩小搜索范围,直到找到目标元素或搜索范围为空。最后,在主函数中,我们定义了一个有序的整数向量arr和目标元素target,并调用interpolationSearch라는 함수를 정의합니다. 대상 요소가 발견되면 해당 인덱스 위치를 인쇄하고, 대상 요소를 찾을 수 없으면 해당 프롬프트 정보를 인쇄합니다.

  1. 결론
    보간 검색 알고리즘은 알려진 데이터의 분포를 기반으로 대상 요소를 빠르게 찾을 수 있는 향상된 검색 알고리즘입니다. 이 문서에서는 보간 검색 알고리즘의 개념을 소개하고 C++에서 보간 검색 알고리즘을 구현하기 위한 코드 예제를 제공합니다. 독자들이 이 기사를 통해 C++에서 보간 검색 알고리즘을 사용하는 방법을 익히고, 실제 응용에서 유연하게 사용할 수 있기를 바랍니다.

위 내용은 C++에서 보간 검색 알고리즘을 사용하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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