把第一个元素与第二个元素比较,如果第一个比第二个大,则交换他们的位置。接着继续比较第二个与第三个元素,如果第二个比第三个大,则交换他们的位置….
    这个算法的名字由来是因为越小的元素会经由交换慢慢“浮”到数列的顶端(升序或降序排列),就如同碳酸饮料中二氧化碳的气泡最终会上浮到顶端一样,故名“冒泡排序”。

    排序步骤(n个数升序为例):
    1)第一轮:用第一个和第第二个比较,把更大的放在第二位,然后用第二位和第三位比较,把更大的放在第三位……直到第一轮结束,比较了n-1次,最大的那个数放在最后的位置。
    2)第二轮:重复第一个步骤,不过不需要和最后一个比较,因为最后一个肯定是最大的,比较了n-2次,第二大的数放在了倒数第二个位置。
    3)……
    ……
    n-1)第n-1轮:把第一个和第二个数比较,较大的放在第二位。小的放在第一位,比较了1次,排序完成。

    动图如下:
    1.冒泡排序 - 图1

    java代码简单实现:

    1. public class BubbleSort implements IArraySort {
    2. @Override
    3. public int[] sort(int[] sourceArray) throws Exception {
    4. for (int i = 1; i < arr.length; i++) {
    5. for (int j = 0; j < arr.length - i; j++) {
    6. if (arr[j] > arr[j + 1]) {
    7. int tmp = arr[j];
    8. arr[j] = arr[j + 1];
    9. arr[j + 1] = tmp;
    10. }
    11. }
    12. }
    13. return arr;
    14. }
    15. }


    public class BubbleSort implements IArraySort {
    
        @Override
        public int[] sort(int[] sourceArray) throws Exception {
            // 对 arr 进行拷贝,不改变参数内容
            int[] arr = Arrays.copyOf(sourceArray, sourceArray.length);
    
            for (int i = 1; i < arr.length; i++) {
                // 设定一个标记,若为true,则表示此次循环没有进行交换,也就是待排序列已经有序,排序已经完成。
                boolean flag = true;
    
                for (int j = 0; j < arr.length - i; j++) {
                    if (arr[j] > arr[j + 1]) {
                        int tmp = arr[j];
                        arr[j] = arr[j + 1];
                        arr[j + 1] = tmp;
    
                        flag = false;
                    }
                }
    
                if (flag) {
                    break;
                }
            }
            return arr;
        }
    }