原文: https://howtodoinjava.com/algorithm/bubble-sort-java-example/
冒泡排序是一种简单而缓慢的排序算法,它会反复浏览整个集合,比较每对相邻元素,并以错误的顺序交换它们。 在排序算法中,如果您观察元素以较高顺序(即较大的值)移动,它们就像水中的气泡,从底部到顶部(从数组的一侧/中间到另一侧)缓慢漂浮。
您可以想象在每一步上都有大气泡漂浮并停留在表面。 在该步骤中,当没有气泡移动时,排序停止。
冒泡排序算法
冒泡排序算法的基本思想可以描述为以下步骤:
- 数据元素分为两部分:已排序部分和未排序部分。
- 遍历未排序部分中的每个元素,并与相邻元素重新排列其位置,以将具有较高顺序的元素放在较高位置。 最后,顺序最高的元素将位于未排序部分的顶部,并移至已排序部分的底部。
- 重复步骤 2,直到未排序的部分中没有剩余的元素。

冒泡排序算法
冒泡排序 Java 示例
public class BubbleSortExample{public static void main(String[] args){// This is unsorted arrayInteger[] array = new Integer[] { 12, 13, 24, 10, 3, 6, 90, 70 };// Let's sort using bubble sortbubbleSort(array, 0, array.length);// Verify sorted arraySystem.out.println(Arrays.toString(array));}@SuppressWarnings({ "rawtypes", "unchecked" })public static void bubbleSort(Object[] array, int fromIndex, int toIndex){Object d;for (int i = toIndex - 1; i > fromIndex; i--){boolean isSorted = true;for (int j = fromIndex; j < i; j++){//If elements in wrong order then swap themif (((Comparable) array[j]).compareTo(array[j + 1]) > 0){isSorted = false;d = array[j + 1];array[j + 1] = array[j];array[j] = d;}}//If no swapping then array is already sortedif (isSorted)break;}}}Output: [3, 6, 10, 12, 13, 24, 70, 90]
冒泡排序性能和复杂度
- 冒泡排序属于
O(n^2)排序算法,这使得排序大型数据量效率很低。 - 冒泡排序既是稳定的,又是自适应的。
- 对于几乎排序的数据,冒泡排序需要
O(n)时间,但至少需要 2 次通过数据。 - 如果输入通常是按排序顺序,但偶尔可能有一些乱序的元素几乎在适当的位置,则这是可行的。
- 在大型集合的情况下,应避免冒泡排序。
- 在逆序集合的情况下,效率不高。
学习愉快!
