vlambda博客
学习文章列表

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)