冒泡排序是交换排序的其中一种。

从前往后,两两比较遍历数组。一次遍历排好一个数,N个数则需遍历N次。时间复杂度为 O(N^2)。
//冒泡排序
void BubbleSort(DataType* a,int n) {
int exchange = 0;
for (int j = 0; j < n; j++) {
for (int i = 1; i < n - j ; i++) { //一轮排好一个,排好一个后便不用再排了,剩余的数虽这j(一轮排好一个)的变化而变化
if (a[i - 1] > a[i]) {
Swap(&a[i - 1], &a[i]);
exchange = 1;
}
}
if (exchange == 0) { //若遍历一轮发现exchange==0,则说明没有发生交换,则已经是有序的了
break;
}
}
}
从前往后,两两比较遍历数组。一次遍历排好一个数,N个数则需遍历N次。时间复杂度为 O(N^2)。
无额外开辟新的空间。空间复杂度为 O(1)。