1. 程式人生 > 實用技巧 >排序4:希爾排序

排序4:希爾排序

/**
* @desc: 希爾排序
* @author: 毛會懂
* @create: 2020-12-23 14:21:00
**/
public class Shell {

public static void sort(Comparable[] arr){
int n = arr.length;
int h = 1; //根據陣列a的長度,確定增長量h的初始值
while (h < (n >>>1)){ //n >>>1 等價於 n / 2
h = h << 1 + 1; // h = h * 2 + 1
}

while (h >=1){//控制 增量變化 重新排序的次數
//插入排序(第一組的第二個元素,對應第h個元素,第二組的第二個元素,對應第h+1個元素)
for(int i = h;i < n;i++){
//插入排序
for(int j = i;j >= h;j-=h){
if(isExchange(arr[j-h],arr[j])){
exchange(arr,j-h,j);
}else{
break;
}
}
}
h = h >>> 1; // h = h / 2
}
}

private static Boolean isExchange(Comparable o1,Comparable o2){
return o1.compareTo(o2) > 0;
}

private static void exchange(Comparable[] arr,int i,int j){
Comparable temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;
}
}

//希爾排序
public static void main(String[] args) {
Integer[] arr = {10,8,20,30,5,7,4,12,40,30,1,2,4,3,100,5,32,45,23,66,45,7,55,79,6};
Shell.sort(arr);
Arrays.asList(arr).forEach(System.out::println);

Person[] persions = {new Person("b",11),new Person("a",10),new Person("c",12),new Person("b",111),
new Person("a",5),new Person("c",4)};
Insertion.sort(persions);
for (Person person : persions) {
System.out.println(person);
}
}