冒泡排序

/**
 * 冒泡排序,a是数组,n表示数组大小
 */
public static void bubbleSort(int[] a, int n) {
    if (n <= 1) return;

    for (int i = 0; i < n; ++i) {
        // 提前退出标志位
        boolean flag = false;
        for (int j = 0; j < n - i - 1; ++j) {
            if (a[j] > a[j + 1]) { // 交换
                int tmp = a[j];
                a[j] = a[j + 1];
                a[j + 1] = tmp;
                // 此次冒泡有数据交换
                flag = true;
            }
        }
        if (!flag) break;  // 没有数据交换,提前退出
    }
}

/**
 * 向下冒泡。可能比冒泡更易懂
 */
private static void bubbleDownSort(int[] arr) {
    int len = arr.length;
    if (len == 1) return;

    for (int i = 0; i < len; i++) {
        for (int j = i + 1; j < len; j++) {
            if (arr[i] > arr[j]) {
                int tmp = arr[i];
                arr[i] = arr[j];
                arr[j] = tmp;
            }
        }
    }
}

你可能感兴趣的:(冒泡排序)