在C++中使用二分查找算法可以通过以下步骤实现:
首先,确定要查找的目标元素target以及待查找的有序数组arr。
定义两个变量low和high,分别表示查找范围的最低和最高索引。
在while循环中,当low小于等于high时,进行查找操作。
在循环体内,计算中间索引mid = (low + high) / 2,并取出arr[mid]的值。
根据arr[mid]与target的大小关系,更新low和high的值,缩小查找范围。
如果找到目标元素,返回目标元素的索引;如果未找到目标元素,返回-1表示未找到。
以下是一个使用二分查找算法查找目标元素target在有序数组arr中的索引的示例代码:
#include <iostream>
#include <vector>
int binarySearch(std::vector<int>& arr, int target) {
int low = 0;
int high = arr.size() - 1;
while (low <= high) {
int mid = low + (high - low) / 2;
if (arr[mid] == target) {
return mid;
} else if (arr[mid] < target) {
low = mid + 1;
} else {
high = mid - 1;
}
}
return -1;
}
int main() {
std::vector<int> arr = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
int target = 6;
int result = binarySearch(arr, target);
if (result != -1) {
std::cout << "Target element found at index: " << result << std::endl;
} else {
std::cout << "Target element not found in the array" << std::endl;
}
return 0;
}
在上面的示例代码中,我们定义了一个名为binarySearch的函数,用于执行二分查找算法。我们首先定义了一个有序数组arr和目标元素target,然后调用binarySearch函数进行查找,并输出结果。