c语言中冒泡排序怎么才能使输入的数据是可变的
时间: 2024-09-06 07:01:27 浏览: 29
在C语言中实现冒泡排序算法时,要使输入的数据是可变的,通常需要通过函数参数传递数组和数组的大小。在主函数中根据需要填充数组,并将其和数组的大小传递给排序函数。这样,排序函数就可以处理不同大小和内容的数组了。下面是一个简单的冒泡排序示例代码:
```c
#include <stdio.h>
// 冒泡排序函数,arr为待排序数组,n为数组元素个数
void bubbleSort(int arr[], int n) {
int i, j, temp;
for (i = 0; i < n-1; i++) {
for (j = 0; j < n-i-1; j++) {
if (arr[j] > arr[j+1]) {
// 交换两个元素的位置
temp = arr[j];
arr[j] = arr[j+1];
arr[j+1] = temp;
}
}
}
}
// 主函数,用于演示冒泡排序
int main() {
int data[] = {64, 34, 25, 12, 22, 11, 90};
int n = sizeof(data)/sizeof(data[0]);
printf("原始数组: \n");
for (int i = 0; i < n; i++) {
printf("%d ", data[i]);
}
printf("\n");
bubbleSort(data, n);
printf("排序后的数组: \n");
for (int i = 0; i < n; i++) {
printf("%d ", data[i]);
}
printf("\n");
return 0;
}
```
在上面的代码中,`bubbleSort`函数接受两个参数:`arr`代表数组,`n`代表数组中元素的个数。`main`函数中创建了一个整型数组`data`,并计算了它的大小`n`,然后调用`bubbleSort`函数进行排序。如果想对不同的数组进行排序,只需要在`main`函数中改变`data`数组的内容或者大小即可。
阅读全文