插入排序是一种比较简单而又神奇的排序算法,插入排序的基本思路简单,平均时间复杂度为O(n^2)。但是如果所排序数组是近乎有序的,则它的时间复杂度为O(n),这是高级排序算法也达不到的时间复杂度。代码如下:
public void insertionSort(int []a,int n)
{
for(int i=0;i<n;i++)//选择将要插入的数
{
for(int j=i;j>0;j--)//选择将要插入的地方
{
int k=0;
if(a[j]<a[i])//交换位置
k=a[j];
a[j]=a[i];
a[i]=k;
else
break;
}
}
}
这段代码就是用java实现的插入排序的代码,这段代码可优化的地方就是在交换位置那一步,交换位置一共需要三次赋值,这是非常浪费时间的。可以考虑将选择插入
的数赋值给一个中间量,for循环向前遍历,判断该位置是否是应该插入的位置,如果不是就可以将数组向后移,如果是的话,就直接将该数插入合适位置。代码如下
public void insertionSort(int []a,int n)
{
for(int i=0;i<n;i++)
{
int e=a[i];
int j=0;
for( j=i;j>0;j--)
{
if(a[i]<a[j])
a[j]=a[j-1];
else
break;
}
a[j]=e;
}
}
这段代码将三次的赋值缩短到一次,可以将排序的速度大大缩短。