核心:通过构建有序序列,对于未排序序列,从后向前扫描,找到相应位置并插入。实现上通常使用in-place排序(需用到O(1)的额外空间)
实现(C++):
template<typename T>
void insertion_sort(T arr[], int len) {
int i, j;
T temp;
for (int i = 1; i < len; i++) {
temp = arr[i];
for (int j = i - 1; j >= 0 && arr[j] > temp; j--) {
a[j + 1] = a[j];
}
arr[j + 1] = temp;
}
}
性质:
核心:基于插入排序,使数组中任意间隔为h的元素都是有序的,即将全部元素分为h个区域使用插入排序。其实现可类似于插入排序但使用不同增量。更高效的原因是它权衡了子数组的规模和有序性。
实现(C++):
template<typename T>
void shell_sort(T arr[], int len) {
int gap, i, j;
T temp;
for (gap = len >> 1; gap > 0; gap >>= 1)
for (i = gap; i < len; i++) {
temp = arr[i];
for (j = i - gap; j >= 0 && arr[j] > temp; j -= gap)
arr[j + gap] = arr[j];
arr[j + gap] = temp;
}
}