用C语言写一个从前往后确定的冒泡排序
时间: 2023-10-31 09:05:33 浏览: 42
以下是用C语言实现从前往后确定的冒泡排序的代码:
```c
#include <stdio.h>
void bubble_sort(int arr[], int size) {
for (int i = 0; i < size - 1; i++) {
for (int j = 0; j < size - 1 - i; j++) {
if (arr[j] > arr[j + 1]) {
int temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
}
int main() {
int arr[] = {5, 2, 1, 4, 3};
int size = sizeof(arr) / sizeof(arr[0]);
bubble_sort(arr, size);
for (int i = 0; i < size; i++) {
printf("%d ", arr[i]);
}
return 0;
}
```
在上述代码中,我们首先定义了一个 `bubble_sort` 函数,该函数接受一个整数数组以及其大小作为参数,然后在内部使用两个嵌套的循环进行冒泡排序。外部循环控制比较的轮数,内部循环则遍历整个数组并进行元素的比较和交换。如果相邻两个元素的顺序不正确,则交换它们的位置。
在 `main` 函数中,我们定义了一个整数数组,并使用 `sizeof` 运算符来计算数组的大小。然后,我们调用 `bubble_sort` 函数对数组进行排序,并使用循环打印排序后的数组元素。