插入排序

普通插入排序

时间复杂度O(n^2)

public void sort(int[] a) {
    for (int i = 1; i < a.length; i++) {
        int temp = a[i];
        int j = i - 1;
        for (j = i - 1; j >= 0; j--) {
            if (a[j] >= temp) {
                a[j + 1] = a[j];
            } else {
                break;
            }
        }
        a[j + 1] = temp;
    }
}
复制代码

折半插入排序

时间复杂度O(n*log(n))

public void sort(int[] a) {
    for (int i = 1; i < a.length; i++) {
        int temp = a[i];
        int low = 0;
        int high = i - 1;
        while (low <= high) {
            int mid = (low + high) >> 1;
            if (a[mid] >= temp) {
                high = mid - 1;
            } else {
                low = mid + 1;
            }
        }
        for (int j = i - 1; j > high; j--) {
            a[j + 1] = a[j];
        }
        a[high + 1] = temp;
    }
}
复制代码

折半双插排序

public void sort(int[] a) {
    for (int i = 1; i < a.length; i+=2) {
        int temp;
        int low;
        int high;
        if (i < a.length - 1) {
            int max = a[i] > a[i+1]? a[i] : a[i+1];
            int min = a[i] <= a[i+1]? a[i] : a[i+1];
            low = 0;
            high = i - 1;
            while (low <= high) {
                int mid = (low + high) >> 1;
                if (a[mid] >= max) {
                    high = mid - 1;
                } else {
                    low = mid + 1;
                }
            }
            for (int j = i - 1; j > high; j--) {
                a[j + 2] = a[j];
            }
            a[high + 2] = max;

            temp = min;
            low = 0;
        }else {
            temp = a[i];
            low = 0;
            high = i - 1;
        }
        while (low <= high) {
            int mid = (low + high) >> 1;
            if (a[mid] >= temp) {
                high = mid - 1;
            } else {
                low = mid + 1;
            }
        }
        for (int j = i - 1; j > high; j--) {
            a[j + 1] = a[j];
        }
        a[high + 1] = temp;
    }
复制代码
© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享