直接插入排序

直接插入排序是一个比较简单的排序算法。作用是将一组数排序成升序的。

1. 特性

  • 元素集合越接近有序,直接插入排序算法的时间效率越高。
  • 时间复杂度:O(n^2)
  • 空间复杂度:0(1),它是一种稳定的排序算法。
  • 稳定性:稳定

2. 步骤

下面以 5 4 3 6 2 这组数作为例子来讲解。

直接插入排序就像是在打扑克牌一样,打牌的人会将有序的牌排在一起打出,在这里一组有序的数就相当于是顺子。



1.定义一个 iji 从1下标开始,而 j 是在 i 减1的位置,也就是在 i 的前面。



2.定义一个 tmp 来存放当前 i 下标的值,比较 j,和 tmp 的值,如果 j 下标的值大于 tmp 的值,j 往左边走一次。
在这里插入图片描述


3. 当前 j 下标的值大于 tmp 的值, j 下标的值往右边走一次。



4.j 变量往左走一次如果此时 j 此时小标位置小于0,则说明 i 左边的值都已经排序完成了。



5.将 tmp 的值放到 j+1 下标的位置,也就是当前的0下标。

这就完成了一次插入排序,现在这组数就变成了 4 5 3 6 2。




6.i++,找到 i 下标的下一个位置。j 变量要始终指向 i 下标位置的前一个位置。(i - 1)



7.将此时 i 下标的值放到tmp中,比较 j 下标和tmp的值。



8. j 下标的值大于tmp的值,将 j 下标的值放到 j 后面的一个位置。




9.将 j 此时往左走一次,指向了0下标的位置。此时 j 下标的值大于tmp的值,将 j 下标的值往后走一个。



10. j 此时往左走一次,指向了-1下标的位置。将tmp的值放到 j 下标之前的位置。


此时又排好了一个数据,排序剩下的数据步骤类似,这里就不 演示了。总之就是 i 要一直++找到下一个数据,直到数组有序为止。

最终会排序成 2 3 4 5 6。

3. 代码实现

    //直接插入排序
    public static void insertSort(int[] array) {
        //i下标从数组的第二个值开始
        for (int i = 1; i < array.length ; i++) {
            int tmp = array[i];//tmp存放i下标的值
            int j = i - 1;//j下标为i的前一个位置
            for (; j >= 0; j--) {
                if (array[j] > tmp) {
                    //j下标的值大,将j下标的值放到j的下一个位置
                    array[j + 1] = array[j];
                }else {
                    //j下标的值较小,j小标的值要直接放到j的下一个位置
                   break;
                }
            }
            //此时j下标的值是负数了,将tmp的值放到j变量的后一个位置
            array[j + 1] = tmp;
        }
    }

4. 稳定性

一个本身就稳定的排序,可以实现为不稳定的排序;但是一个本身就不稳定的排序,不能实现为稳定的排序。


用下面的例子来演示直接插入排序的稳定性。

一、如果判断条件是 j 下标的值大于tmp的值。


tmp中会存此时 i 下标的值,此时的 j 下标的值不大于tmp的值,tmp的值还会放到原来的位置。

  1. 执行前:

  2. 执行后:

可以发现排序完成后,两个数字5的顺序没有改变,此时是稳定的。

二、如果判断条件是 j 下标的值大于或者等于tmp的值

tmp中会存此时 i 下标的值,此时的 j 下标的值大于tmp的值,i 下标的值走到后面的一个位置,再将tmp的值放到此时 j +1 下标的位置。


可以发现排序完成后,两个数字5的顺序改变了,此时是不稳定的。


Logo

旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐