Java教程

java希尔排序

本文主要是介绍java希尔排序,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

1959年Shell发明,第一个突破O(n2)的排序算法,是简单插入排序的改进版。它与插入排序的不同之处在于,它会优先比较距离较远的元素。希尔排序又叫缩小增量排序

 算法描述

先将整个待排序的记录序列分割成为若干子序列分别进行直接插入排序,具体算法描述:

  • 选择一个增量序列t1,t2,…,tk,其中ti>tj,tk=1;
  • 按增量序列个数k,对序列进行k 趟排序;
  • 每趟排序,根据对应的增量ti,将待排序列分割成若干长度为m 的子序列,分别对各子表进行直接插入排序。仅增量因子为1 时,整个序列作为一个表来处理,表长度即为整个序列的长度。

package study;

import java.util.Arrays;

public class test {

    public static void main(String[] args) {
        int arr[] = new int[]{5, 4, 9, 2, 7, 3, 1, 8};
        sort(arr);
        System.out.println(Arrays.toString(arr));
    }


    public static void sort(int[] arr) {
        for (int grp = arr .length/2;grp>0;grp/=2){
            for(int i = grp;i<arr.length;i++){
                for(int j= i-grp;j>=0;j-= grp){
                    if (arr[j] > arr[j+grp]){
                            int temp = arr[j];
                            arr[j]=arr[j+grp];
                            arr[j+grp] = temp;
                    }else {
                        break;
                    }
                }
            }
        }
    }


}
这篇关于java希尔排序的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!