基本理念: 一个数组中的每个元素与前面的元素比较,如果前面那一个大,那么继续向前比较,直到找到比这个元素小的数,并排在它后面。
插入排序是从第1个数(不是第0个,因为第0个算是已经排好顺序了) ,逐个与前面的一个数比较,如果第i小,则与第i-1个熟进行交换,直到前面的那个数比它小,然后将前面那个数的位置i-1再+1,得到正确的位置。
#include "../utils.h"
void insertion_sort(int arr[], int len)
{
int i, j, key;
for (i = 1; i < len; i++)
{
key = arr[i];
// 往后挪动比key小的值
for (j = i; j >= 1 && key < arr[j - 1]; j--)
arr[j] = arr[j - 1];
// 将key放到正确位置
arr[j] = key;
}
}
int main(int argc, char const *argv[])
{
test(&insertion_sort);
return 0;
}