java算法-插入排序

Posted JAVA菜鸟程序猿

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java算法-插入排序相关的知识,希望对你有一定的参考价值。

一、原理

插入排序(Insertion-Sort)的算法描述是一种简单直观的排序算法。它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。插入排序在实现上,通常采用in-place排序(即只需用到O(1)的额外空间的排序),因而在从后向前扫描过程中,需要反复把已排序元素逐步向后挪位,为最新元素提供插入空间。


二、代码

 public static int[] insertSort(int[] arr){ if (arr == null || arr.length==1){ return null; } for (int i=1;i<arr.length;i++){ int insertVal = arr[i];//需要插入的值 //9,2,1,5,3,8,10,11,6,4 int index = i-1;//前一个元素的下标 //当前下标索引大于等于0且要插入的值小于它前一个元素的值 while(index >= 0 && insertVal < arr[index]){ arr[index+1] = arr[index]; index--; } arr[index+1] = insertVal; } return arr; }

插入排序的时间复杂度:

在最好的情况下(元素已经排好顺序):那么只需要循环 n-1 次就可以了,时间复杂度 O(n)

在最差的情况下 (元素是逆序的):要循环调整次数:[ n * (n-1) ] / 2 ,时间复杂度为 O(n ^ 2)

平均时间复杂度为:O(n ^ 2)


插入排序的空间复杂度:O(1)

以上是关于java算法-插入排序的主要内容,如果未能解决你的问题,请参考以下文章

排序算法之冒泡选择插入排序(Java)

Java常用的八种排序算法与代码实现

直接插入排序算法——Java实现

Java插入排序

Java插入排序

Java 插入排序算法