一个c语言程序完成顺序查找与折半查找代码实现
时间: 2024-03-15 21:46:15 浏览: 100
顺序查找和折半查找(C语言)
下面是一个完整的 C 语言程序,包含了顺序查找和折半查找的代码实现:
```c
#include <stdio.h>
// 顺序查找
int sequential_search(int arr[], int n, int target) {
for (int i = 0; i < n; i++) {
if (arr[i] == target) {
return i; // 返回目标元素的下标
}
}
return -1; // 如果数组中不存在目标元素,则返回-1
}
// 折半查找
int binary_search(int arr[], int n, int target) {
int left = 0, right = n - 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; // 如果数组中不存在目标元素,则返回-1
}
int main() {
int arr[] = {1, 3, 5, 7, 9};
int n = sizeof(arr) / sizeof(arr[0]);
int target = 5;
// 顺序查找
int index1 = sequential_search(arr, n, target);
if (index1 != -1) {
printf("目标元素 %d 在数组中的下标为 %d(顺序查找)\n", target, index1);
} else {
printf("数组中不存在目标元素 %d(顺序查找)\n", target);
}
// 折半查找
int index2 = binary_search(arr, n, target);
if (index2 != -1) {
printf("目标元素 %d 在数组中的下标为 %d(折半查找)\n", target, index2);
} else {
printf("数组中不存在目标元素 %d(折半查找)\n", target);
}
return 0;
}
```
这个程序首先定义了顺序查找和折半查找两个函数,然后在 `main` 函数中初始化了一个数组和目标元素,分别调用了这两个函数进行查找,并打印查找结果。
阅读全文