版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_21918021/article/details/89022358
四、希尔排序(Shell Sort)
1959年Shell发明,第一个突破O(n^2)的排序算法,是简单插入排序的改进版。它与插入排序的不同之处在于,它会优先比较距离较远的元素。希尔排序又叫缩小增量排序。
希尔排序的核心在于间隔序列的设定。既可以提前设定好间隔序列,也可以动态的定义间隔序列。动态定义间隔序列的算法是《算法(第4版》的合著者Robert Sedgewick提出的。
算法描述
小提示:插入排序相当去增量为1的希尔排序。
先将整个待排序的记录序列分割成为若干子序列分别进行直接插入排序,具体算法描述:
选择一个增量序列t1,t2,…,tk,其中ti>tj,tk=1;
按增量序列个数k,对序列进行k 趟排序;
每趟排序,根据对应的增量ti,将待排序列分割成若干长度为m 的子序列,分别对各子表进行直接插入排序。仅增量因子为1 时,整个序列作为一个表来处理,表长度即为整个序列的长度。
算法分析
大概是O(n3/2)
过程演示
动图展示
代码实现
package cn.fuqiang.arithmetic;
import java.util.Comparator;
/**
* 希尔排序
* (建议:研究希尔排序前先理解插入排序)
*/
public static void shellSort(int[] arr) {
int increment = arr.length;
while(increment > 1) { //动态定义间隔序列
increment =increment/3+1;
for (int i = increment; i < arr.length; i++) {
int temp = arr[i];
int j ;
for (j = i-increment; j >= 0; j-=increment) {
if(arr[j]> temp){
arr[j+increment] = arr[j];
}
else {
break;
}
}
arr[j+increment] = temp;
}
}
System.out.println(Arrays.toString(arr));
}
//简洁写法
public static void shellSort(int[] arr) {
int increment = arr.length;
while(increment > 1) { //动态定义间隔序列
increment =increment/3+1;
for (int i = increment; i < arr.length; i++) {
int temp = arr[i];
int j ;
for (j = i-increment; j >= 0 && arr[j]> temp ; j-=increment) {
arr[j+increment] = arr[j];
}
arr[j+increment] = temp;
}
}
}