最简单的排序算法之一是插入排序
插入排序由N-1趟(pass)排序组成,对于P=1趟到p=N-1趟,插入排序保证从位置0到位置P上的元素为已排序状态。
插入排序利用这样的事实:位置0到位置P-1上的元素都是已排序过的。
简单来说就是长度为N的序列,前P个元素有序,第P+1个到第N—1个元素为无序,则将第P+1个元素与前P个元素逐个比较,逆序交换,看上去就像往前P个有序序列的合适位置插入一个元素,直到所有无序元素都插入到有序中。
算法描述:
1. 从第一个元素开始,只有一个元素时认为是有序的
2. 取出下一个元素,在已经排序的元素序列中从后向前扫描
3. 如果该元素(已排序)大于新元素,将该元素移到下一位置
4. 重复步骤 3,直到找到已排序的元素小于或者等于新元素的位置
5. 将新元素插入到该位置后
6. 重复步骤 2~5
代码如下:
void Sort::insertSort(int (&a)[10], int n){
int i, position;