编写程序,所完成的功能为:(1)建立数组,元素为12, 21, 5, 25, 31, 11, 30, 26, 53, 87, 20, 3, 65, 48, 67, 91。(2)使用快速排序法对数组进行排序。(3)使用二分查找法,搜索元素3的位置。用c语言
时间: 2023-10-06 12:14:03 浏览: 30
以下是使用C语言实现的程序:
```c
#include <stdio.h>
// 快速排序
void quick_sort(int arr[], int left, int right)
{
if (left < right) {
int i = left;
int j = right;
int pivot = arr[left]; // 选取左端点为基准值
while (i < j) {
// 从右向左找到第一个小于基准值的元素
while (i < j && arr[j] >= pivot) {
j--;
}
if (i < j) {
arr[i++] = arr[j];
}
// 从左向右找到第一个大于基准值的元素
while (i < j && arr[i] < pivot) {
i++;
}
if (i < j) {
arr[j--] = arr[i];
}
}
// 把基准值放到正确的位置上
arr[i] = pivot;
// 分别对左半部分和右半部分进行快速排序
quick_sort(arr, left, i - 1);
quick_sort(arr, i + 1, right);
}
}
// 二分查找
int binary_search(int arr[], int left, int right, int target)
{
int mid;
while (left <= right) {
mid = (left + right) / 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[] = {12, 21, 5, 25, 31, 11, 30, 26, 53, 87, 20, 3, 65, 48, 67, 91};
int n = sizeof(arr) / sizeof(arr[0]);
int i;
// 快速排序
quick_sort(arr, 0, n - 1);
// 输出排序后的数组
printf("排序后的数组:\n");
for (i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
printf("\n");
// 二分查找元素3
int pos = binary_search(arr, 0, n - 1, 3);
if (pos != -1) {
printf("元素3的位置是:%d\n", pos);
} else {
printf("元素3不存在!\n");
}
return 0;
}
```
输出结果为:
```
排序后的数组:
3 5 11 12 20 21 25 26 30 31 48 53 65 67 87 91
元素3的位置是:0
```