写一个 “冒泡法”函数,在主函数中由键盘输入10个数存入数组,调用函数对数组中的数据进行排序后按从小到大的次序输出,要求从键盘输入10个整数,数据输入、输出均用指针操作。
时间: 2024-02-03 10:14:23 浏览: 100
以下是冒泡排序的函数实现:
```c
void bubble_sort(int *arr, int len) {
for (int i = 0; i < len - 1; i++) {
for (int j = 0; j < len - i - 1; j++) {
if (arr[j] > arr[j + 1]) {
int temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
}
```
在主函数中,我们可以先定义一个长度为 10 的整型数组,再通过指针操作从键盘输入 10 个数:
```c
#include <stdio.h>
void bubble_sort(int *arr, int len);
int main() {
int arr[10];
int *p = arr;
printf("请输入10个整数:\n");
for (int i = 0; i < 10; i++) {
scanf("%d", p + i);
}
bubble_sort(arr, 10);
printf("排序后的结果为:\n");
for (int i = 0; i < 10; i++) {
printf("%d ", *(p + i));
}
return 0;
}
```
在上述代码中,我们通过 `scanf` 函数将从键盘输入的值存入指针 `p` 所指向的内存空间中,然后调用 `bubble_sort` 函数对数组进行排序,最后通过指针操作输出排序后的结果。
阅读全文