1.输入随机生成0≦x≦109数组,长度分别为5、10、100; 2.采用三种排序(快速排序、归并排序、自选一类排序算法)输出每次执行的排序结果给出c语言代码
时间: 2024-10-15 15:18:14 浏览: 31
首先,让我们分别生成长度为5、10和100的随机整数数组,并介绍如何用C语言实现这三种排序算法:
1. 首先,我们需要包含必要的头文件,声明数组,然后用`rand()`函数生成随机数:
```c
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
// 生成指定范围内的随机数
int random_number(int min, int max) {
return min + rand() % (max - min + 1);
}
// 初始化随机数种子
void seed_random() {
srand(time(0));
}
```
2. 然后,我们可以创建三个不同的函数,每个代表一种排序算法:
- **快速排序**(quicksort)
```c
void quicksort(int arr[], int low, int high) {
if (low < high) {
int pivot = partition(arr, low, high);
quicksort(arr, low, pivot - 1);
quicksort(arr, pivot + 1, high);
}
// 具体实现略,参考标准库或网上的教程
}
```
- **归并排序**(mergesort)
```c
void mergesort(int arr[], int left, int right) {
if (left < right) {
int mid = left + (right - left) / 2;
mergesort(arr, left, mid);
mergesort(arr, mid + 1, right);
merge(arr, left, mid, right);
}
// 具体实现略,涉及两个临时数组和合并操作
}
```
- **自选排序算法**(例如选择排序,segsort等),这里假设我们使用插入排序作为例子,因为它是简单的直观排序算法:
```c
void insertion_sort(int arr[], int n) {
for (int i = 1; i < n; ++i) {
int key = arr[i];
int j = i - 1;
while (j >= 0 && arr[j] > key) {
arr[j + 1] = arr[j];
j--;
}
arr[j + 1] = key;
}
}
```
为了生成不同长度的数组并应用这些排序,你需要创建循环,比如:
```c
int main() {
int lengths[] = {5, 10, 100};
const int num_lengths = sizeof(lengths) / sizeof(lengths[0]);
for (int i = 0; i < num_lengths; ++i) {
int arr[lengths[i]];
// 生成数组...
seed_random();
for (int j = 0; j < lengths[i]; ++j)
arr[j] = random_number(0, 1e9);
printf("Length %d:\n", lengths[i]);
printf("[ ");
for (int k : arr)
printf("%d ", k);
printf("]\n");
switch (i) {
case 0:
quicksort(arr, 0, lengths[i] - 1);
break;
case 1:
mergesort(arr, 0, lengths[i] - 1);
break;
case 2:
insertion_sort(arr, lengths[i]);
break;
}
printf("Sorted array after %s:\n", i == 0 ? "quick sort" :
i == 1 ? "merge sort" : "insertion sort");
// 输出排序后的数组
}
return 0;
}
```
请注意,以上代码示例并未包含完整的细节,如错误处理和算法的具体实现部分。你可以参考C语言的标准库或其他资源来完善它们。
阅读全文