- Published on
冒泡
- Authors

- Name
- 李丹秋
function bubbleSort(arr) {
let n = arr.length;
for (let i = 0; i < n - 1; i++) {
// 标记变量,用于检测这一轮是否进行了交换
let swapped = false;
for (let j = 0; j < n - 1 - i; j++) {
if (arr[j] > arr[j + 1]) {
// 交换元素
let temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
swapped = true;
}
}
// 如果没有进行交换,说明数组已经有序,提前退出
if (!swapped) {
break;
}
}
return arr;
}
// 测试冒泡排序
let arr = [64, 34, 25, 12, 22, 11, 90];
console.log("排序前的数组: ", arr);
let sortedArr = bubbleSort(arr);
console.log("排序后的数组: ", sortedArr);
在冒泡排序中,只有交换才可以改变两个元素的前后顺序。为了保证冒泡排序算法的稳定性,当有相邻的两个元素大小相等的时候,我们不做交换,相同大小的数据在排序前后不会改变顺序,所以冒泡排序是稳定的排序算法。
冒泡的过程只涉及相邻数据的交换操作,只需要常量级的临时空间,所以它的空间复杂度为 O(1),是一个原地排序算法。
最好情况下,要排序的数据已经是有序的了,我们只需要进行一次冒泡操作,就可以结束了,所以最好情况时间复杂度是 O(n)。而最坏的情况是,要排序的数据刚好是倒序排列的,我们需要进行 n 次冒泡操作,所以最坏情况时间复杂度为 O(n2)。