直接插入排序的基本思想:把待排序的记录按其关键码值的大小逐个插入到一个已经排好序的有序序列中,直到所有的记录插入完为止,得到一个新的有序序列 。
一、步骤
1.给定一个乱序的数组,如
从第一个元素开始排序,当只有第一个元素4时,我们可以认为它是有序的。
2.然后取出下一个元素,在这里是第二个元素即5,将这个元素赋值变量tmp,然后进行插入
3.如果前一个元素大于tmp,则该元素向后移,重复上述步骤,直到找到小于tmp的位置
4.找到小于tmp元素的位置后,插入到该元素的后面,就完成了一次插入排序
图片演示:
重复上述步骤,直到排序结束。
二、代码
void InsertSort(int* arr, int n) //n是数组的大小 n = sizeof(arr)/sizeof(int)
{
for (int i = 0; i < n - 1; i++) //i < n - 1而不是小于n是为了避免越界访问
{
int end = i; //到[0,end]是一个有序的数组
int tmp = arr[end + 1];
while (end >= 0)
{
if (arr[end] > tmp)
{
arr[end + 1] = arr[end];
end--;
}
else
{
break;
}
} //出循环时,end指向的是小于tmp元素的位置。当end = -1时,
代表tmp的值是在有序数组中最小的值
arr[end + 1] = tmp;
}
}