排序(sorting )的功能是将一个数据元素的任意序列,重新排列成一个按关键字有序的序列。根据排序时待排序的数据元素数量的不同,使得排序过程中涉及的存储器不同,可以将排序方法分为两类。一类是整个排序过程在内存储器中进行,称为内部排序;另一类是由于待排序元素数量太大,以至于内存储器无法容纳全部数据,排序需要借助外部存储设备才能完成,这类排序称为外部排序。
1.插入排序(直接插入排序、希尔排序)
1.1 直接插入排序
直接插入排序是一种最简单的插入排序方法,它的基本思想是:仅有一个元素的序列总是有序的,因此,对 n 个记录的序列,可从第二个元素开始直到第 n 个元素,逐个向有序序列中执行插入操作,从而得到n 个元素按关键字有序的序列。
一般来说,在含有j-1 个元素的有序序列中插入一个元素的方法是:从第j-1 个元素开始依次向前搜索应当插入的位置,并且在搜索插入位置的同时可以后移元素,这样当找到适当的插入位置时即可直接插入元素。
一般来说,在含有j-1 个元素的有序序列中插入一个元素的方法是:从第j-1 个元素开始依次向前搜索应当插入的位置,并且在搜索插入位置的同时可以后移元素,这样当找到适当的插入位置时即可直接插入元素。
以关键字序列{ 26 , 53 , 48 , 11 , 13 , 48 , 32 , 15}为例
代码1:
public void StraightInsertSort(double[] sorted){
int sortlen =sorted.length;
for(int i=2;i<sortlen;i++){
if(sorted[i]<sorted[i-1]){
sorted[0]=sorted[i];
sorted[i]=sorted[i-1];
int insertpos =0; //插入位置
for(int j=i-2;j>=0;j--){
if(sorted[j]>sorted[0]){
sorted[j+1]=sorted[j];
}else{
insertpos = j+1;
break;
}
}
sorted[insertpos]=sorted[0];
}
}
}
代码2:
public void insertSort(Object[] r, int low, int high){
for (int i=low+1; i<=high; i++)
if (r[i]<r[i-1]){ //小于时,需将 r[i]插入有序表
Object temp = r[i];
r[i] = r[i-1];
int j=i-2;
for (; j>=low&&temp<r[j]; j--)
r[j+1] = r[j]; //记录后移
r[j+1] = temp; //插入到正确位置
}
}