C语言 二分法查表
时间: 2023-07-24 18:20:30 浏览: 183
二分法查表是一种常见的查找算法,可以在有序表中快速查找指定元素。以下是一个使用C语言实现二分法查表的例子:
```c
#include <stdio.h>
int binary_search(int arr[], int len, int target) {
int left = 0, right = len - 1;
while (left <= right) {
int mid = left + (right - left) / 2;
if (arr[mid] == target) {
return mid;
} else if (arr[mid] < target) {
left = mid + 1;
} else {
right = mid - 1;
}
}
return -1;
}
int main() {
int arr[] = {1, 3, 5, 7, 9, 11, 13, 15};
int len = sizeof(arr) / sizeof(arr[0]);
int target = 7;
int index = binary_search(arr, len, target);
if (index != -1) {
printf("目标元素 %d 在数组中的下标为 %d\n", target, index);
} else {
printf("目标元素 %d 不在数组中\n", target);
}
return 0;
}
```
在这个例子中,我们定义了一个 `binary_search` 函数,它接受一个整型数组 `arr`、数组长度 `len` 和目标元素 `target` 作为参数,并返回目标元素在数组中的下标,如果目标元素不在数组中,则返回 -1。在函数中,我们使用两个指针 `left` 和 `right` 分别指向数组的左右两端,然后不断缩小查找范围,直到找到目标元素或者查找范围为空。具体实现方式是,每次将查找范围的中间位置作为参照点,如果目标元素等于参照点,则直接返回;如果目标元素大于参照点,则将左指针移到参照点右侧;如果目标元素小于参照点,则将右指针移到参照点左侧。这样就可以逐步缩小查找范围,最终找到目标元素或者确定其不存在于数组中。
阅读全文