直接插入排序-java

直接插入排序-java

转载请注明出处:http://blog.csdn.net/a740169405/article/details/50717749

思想:

插入排序是在一个已经有序的小序列的基础上,一次插入一个元素。当然,刚开始这个有序的小序列只有1个元素,就是第一个元素。比较是从有序序列的末尾开始,也就是想要插入的元素和已经有序的最大者开始比起,如果比它大则直接插入在其后面,否则一直往前找直到找到它该插入的位置。

循环实现:

/**
 * 插入排序(循环)
 * @param arr 数组
 */
private static void insertSort(int[] arr) {
    int i = 1;  // 从第二个元素开始
    for (; i < arr.length; i++) {
        int tagNum = arr[i]; // 本次需要被插入的元素
        int j = i - 1;       // while循环的起点
        while (j >= 0 && tagNum < arr[j]) {
            // 当j>=0以及带插入的数比当前位置小,把当前数据往后移一位。
            arr[j + 1] = arr[j];
            j--;
        }
        arr[j + 1] = tagNum;// 直到找到比带插入小的数据,或者到达数组头部时,把数据插入。
    }
}

递归实现:

/**
 * 直接插入排序(递归)
 * @param arr 数组
 * @param index 需要插入的数字数组下标,从0开始
 */
private static void insertSort(int[] arr, int index) {
    if (index < 0 || index >= arr.length) {
        return;
    }
    int tagNum = arr[index];
    int j = index - 1;
    while (j >= 0 && tagNum < arr[j]) {
        arr[j + 1] = arr[j];
        j--;
    }
    arr[j + 1] = tagNum;
    insertSort(arr, index + 1);  // 递归插入下一个元素
}

调用代码:

int[] arr = new int[] {1, 45, 78, 23, 12, 98, 150, 1, 45};
insertSort(arr);
System.out.println(Arrays.toString(arr));
int[] array = new int[] {2, 5, 90, 78, 12, 90, 67, 89, 2, 1};
insertSort(array, 0);
System.out.println(Arrays.toString(array));

结果:
结果

复杂度分析:

最好:当数组已经是排好序的数组,此时不需要移动,只需要比较n-1次,去除常数项,复杂度为n
最坏:当数组是逆序的时候,复杂度最高,此时需要比较的次数为比较次数
记录的移动次数为移动次数
两者想加,得到的最高次幂为2次,去除常数项后,复杂度为n²
也就是说直接插入排序的复杂度为:n-n²

稳定性分析:

如果碰见一个和插入元素相等的,那么插入元素把想插入的元素放在相等元素的后面。所以,相等元素的前后顺序没有改变,从原无序序列出去的顺序就是排好序后的顺序,所以插入排序是稳定的

稳定性参考:http://www.cnblogs.com/codingmylife/archive/2012/10/21/2732980.html

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值