用c++写一个冒泡排序算法
时间: 2024-05-02 16:18:51 浏览: 71
以下是C语言实现的冒泡排序算法:
```c
#include <stdio.h>
void bubble_sort(int arr[], int size) {
int i, j, temp;
for (i = 0; i < size - 1; i++) {
for (j = 0; j < size - i - 1; j++) {
if (arr[j] > arr[j + 1]) {
temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
}
int main() {
int arr[] = {5, 2, 8, 3, 1, 6};
int size = sizeof(arr) / sizeof(arr[0]);
bubble_sort(arr, size);
for (int i = 0; i < size; i++) {
printf("%d ", arr[i]);
}
return 0;
}
```
输出结果为:
```
1 2 3 5 6 8
```
以上实现中,首先定义了一个`bubble_sort`函数用于进行冒泡排序,接着在`main`函数中定义了一个整型数组`arr`,并计算出数组的元素个数。调用`bubble_sort`函数对数组进行排序,最后输出排序后的结果。在`bubble_sort`函数中,使用两层循环进行排序,外层循环控制排序轮数,内层循环控制每轮比较的次数。若前一个元素大于后一个元素,则进行交换。
阅读全文