使用指向一维数组元素的指针作为函数参数,编写冒泡法、选择法实现从小到大排序的函数,并编写main(函数实现排序的C语言程序)
时间: 2024-05-10 07:18:43 浏览: 141
C语言程序设计-编写函数用冒泡排序法对数组中的数据进行从小到大的排序;.c
5星 · 资源好评率100%
以下是使用指向一维数组元素的指针作为函数参数,编写冒泡法、选择法实现从小到大排序的函数,以及实现排序的C语言程序:
```c
#include <stdio.h>
void bubbleSort(int *arr, int len) {
int i, j, temp;
for (i = 0; i < len - 1; i++) {
for (j = 0; j < len - i - 1; j++) {
if (*(arr + j) > *(arr + j + 1)) {
temp = *(arr + j);
*(arr + j) = *(arr + j + 1);
*(arr + j + 1) = temp;
}
}
}
}
void selectionSort(int *arr, int len) {
int i, j, minIndex, temp;
for (i = 0; i < len - 1; i++) {
minIndex = i;
for (j = i + 1; j < len; j++) {
if (*(arr + j) < *(arr + minIndex)) {
minIndex = j;
}
}
if (minIndex != i) {
temp = *(arr + i);
*(arr + i) = *(arr + minIndex);
*(arr + minIndex) = temp;
}
}
}
int main() {
int arr[] = {5, 3, 8, 4, 2};
int len = sizeof(arr) / sizeof(int);
printf("Original array: ");
for (int i = 0; i < len; i++) {
printf("%d ", *(arr + i));
}
bubbleSort(arr, len);
// selectionSort(arr, len); // Uncomment this line to use selection sort
printf("\nSorted array: ");
for (int i = 0; i < len; i++) {
printf("%d ", *(arr + i));
}
return 0;
}
```
在上面的代码中,我们首先定义了两个排序函数 `bubbleSort()` 和 `selectionSort()`,分别实现冒泡排序和选择排序。这两个函数都使用指向一维数组元素的指针作为参数,以及数组的长度。
然后在 `main()` 函数中,我们定义了一个整型数组 `arr`,并初始化了其中的元素。我们使用 `sizeof()` 函数获取数组的长度,并将其赋值给变量 `len`。
接下来,我们调用了 `bubbleSort()` 函数对数组进行排序,并输出排序后的结果。
如果您想使用选择排序,只需将上面代码中的 `bubbleSort(arr, len)` 注释掉,然后取消注释 `selectionSort(arr, len)` 即可。
希望这个例子能帮助您理解如何使用指向一维数组元素的指针来实现排序函数。
阅读全文