通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应的位置并插入。
public static void InsertSort(int[] arr){
int i, j;
int n = arr.Length;
int target;
//假定第一个元素被放到了正确的位置上
//这样,仅需遍历1 - n-1
for (i = 1; i < n; i++)
{
j = i;
target = arr[i];
while (j > 0 && target < arr[j - 1])
{
arr[j] = arr[j - 1];
j--;
}
arr[j] = target;
}
}