二、直接插入排序的三种实现
1.思路
每次将一个待排序的记录,按其关键字大小插入到前面已经排好序的子序列中的适当位置,知道全部记录插入完成为止
设数组为a[0…n-1]
1)初始时,a[0]自成1个有序区,无序区为a[1…n-1]。令i=1
2)将a[i]并入当前的有序区a[0…i-1]中形成a[0…i]的有序区间
3)i++并重复第二步直到i==n-1,排序完成
第一种实现方法
void InsertSort1(int a[], int n)
{
int i, j, k;
for (i = 1; i < n; i++)
{
//为a[i]在前面的a[0…i-1]有序区间中找一个合适的位置
for (j = i - 1; j >= 0; j–)
{
//查到比前面数比a[i]小的那个位置就跳出
if (a[j] < a[i])
break;
}
//如果这个位置不为前面i-1个数的最后一位,则执行下列函数
if (j != i - 1)
{
int temp = a[i];
//将数往后推动
for (k = i - 1; k > j; k–)
{
a[k + 1] = a[k];
}
//把那个数插入到该有的位置
a[k + 1] = temp;
}
}
}
第二种实现方法
void InsertSort2(int a[], int n)
{
int i, j;
for (i = 1; i < n; i++)
{
//判断前面一个数是否大于后面的数
if (a[i] < a[i - 1])
{
//将后面这个数赋给临时变量
int temp = a[i];
//判断i前面的数是否大于临时变量,则前面的值后移
for (j = i - 1; j >= 0 && a[j] > temp; j–)
{
a[j + 1] = a[j];
}
//到了当前位置之后把临时变量赋给它
a[j + 1] = temp;
}
}
}
本博客所有文章除特别声明外,均采用 CC BY-SA 4.0 协议 ,转载请注明出处!