利用分治策略试设计一个算法在n个元素的集合查找待查找元素c语言利用分治策略试设计一个算法在n个元素的集合查找待查找元素c语言
时间: 2024-11-13 08:22:20 浏览: 20
在C语言中,可以使用分治法设计一个高效的二分查找算法来找寻给定集合中的元素。以下是基本步骤:
1. **分治思想**:将数组分为两半,每次都检查中间位置的元素是否是我们正在寻找的目标。如果目标小于中间值,我们在左半部分继续搜索;如果目标大于中间值,我们在右半部分搜索。
2. **函数定义**:创建一个递归函数`binary_search()`,它接受三个参数:已排序的数组`arr`、数组范围的起始索引`low`和结束索引`high`。
```c
int binary_search(int arr[], int low, int high, int target) {
```
3. **基础情况**:
- 如果`low`大于`high`,说明目标不在数组中,返回-1表示未找到;
- 如果`low`等于`high`,则直接比较中间元素是否为目标。
4. **递归调用**:
- 计算中间索引`mid`:`mid = (low + high) / 2`;
- 比较`target`和`arr[mid]`:
- 相等,返回`mid`;
- 小于`arr[mid]`,在左半部分继续递归搜索:`return binary_search(arr, low, mid - 1, target);`
- 大于`arr[mid]`,在右半部分继续递归搜索:`return binary_search(arr, mid + 1, high, target);`
5. **完整代码示例**:
```c
#include <stdio.h>
int binary_search(int arr[], int low, int high, int target) {
if (high >= low) {
int mid = low + (high - low) / 2;
if (arr[mid] == target)
return mid;
else if (arr[mid] > target)
return binary_search(arr, low, mid - 1, target);
else
return binary_search(arr, mid + 1, high, target);
}
// Element not found in array
return -1;
}
int main() {
int arr[] = {1, 2, 3, 4, 5, 6, 7, 8, 9};
int n = sizeof(arr) / sizeof(arr[0]);
int target = 5;
int result = binary_search(arr, 0, n - 1, target);
if (result != -1)
printf("Element found at index %d\n", result);
else
printf("Element not found in the array\n");
return 0;
}
```
阅读全文