美文网首页
p163算法2.3希尔排序

p163算法2.3希尔排序

作者: FiveZM | 来源:发表于2018-01-25 17:32 被阅读0次

/**

  • 希尔排序是一种基于插入排序的快速的排序算法,只需要在插入排序的代码中,将移动元素的距离由1改为h即可,这样
  • 希尔排序的实现就转化了一个类似于插入排序但使用不同增量的过程.
    希尔排序比插入排序和选择排序要快很多,并且数组越大,优势越大
  • @author Zzm

*/

public class ShellSort {
    public static void sort(Comparable[] a){
        int h = 1;
        int N = a.length;
        while(h<N/3)                         //移动元素的间距我们设它不小于数组长度的三分之一
            h = 3*h+1;
        while(h>=1){                         //当间距大于等于1时,至少还可以来一次1和0之间的比较
            for(int i = h;i<N;i++){          //在插入排序中,因为元素的间距是1,所以开始角标是1,那么至少就可以和1-1=0角标做一次比较,
                                             //但在希尔排序中,间距为h,所以我们要初始化i=h,当i++来一直往后,因为j=i,然后就不断和j-h的角标作比较,
                                             //一组比较过程至少2个以上,那个最小那个就交换到前面去
                for(int j = i;j>=h;j-=h){    //出口为j>=h,只要j角标比h大,至少j-h=0,还可以和0角标比较一次,其实理解了插入排序,那么希尔排序也是一样思想的,只是间距h不同
                    if(less(a[j],a[j-h]))    //是否j的值小于j-h的值
                        exch(a,j,j-h);       //j小于j-h那么就交换值的位置
                }
            }
            h = h/3;//间距不断缩小,值到间距为1
        }
    }
    
    private static void exch(Comparable[] a, int j, int i) {     //自定义交换元素的方法
        Comparable temp = a[j];
        a[j] = a[i];
        a[i] = temp;
        
    }

    private static boolean less(Comparable v, Comparable w) {      //自定义判断v是否小于w的方法
        // TODO Auto-generated method stub
        return v.compareTo(w) < 0;
    }

    public static void main(String[] args) {
        
        Integer[] a = new Integer[]{888,494,110,12,154,123,456,356,486,576,16,654,23,451,};
        sort(a);
        for(int num : a){
            System.out.print(" "+num);
        }
    }

}

算法学习来自<算法第四版>书籍

相关文章

  • p163算法2.3希尔排序

    /** 希尔排序是一种基于插入排序的快速的排序算法,只需要在插入排序的代码中,将移动元素的距离由1改为h即可,这样...

  • 排序算法(四) 希尔排序(插入排序的进化)

    参考Java排序算法(四):希尔排序常见排序算法 - 希尔排序 (Shell Sort) 希尔排序算法是按其设计者...

  • 排序算法(二)之希尔排序

    图解排序算法(二)之希尔排序 希尔排序是希尔(Donald Shell)于1959年提出的一种排序算法。希尔排序也...

  • 排序-希尔排序(分治)

    希尔排序 希尔排序,也称递减增量排序算法,是插入排序的一种更高效的改进版本。但希尔排序是非稳定排序算法。 希尔排序...

  • swift经典算法-希尔排序

    希尔排序 希尔排序,也称递减增量排序算法,是插入排序的一种更高效的改进版本。但希尔排序是非稳定排序算法。 希尔排序...

  • 排序算法④——希尔排序

    希尔排序 希尔排序,也称递减增量排序算法,是插入排序的一种更高效的改进版本。但希尔排序是非稳定排序算法。 希尔排序...

  • java实现快速排序、归并排序、希尔排序、基数排序算法...

    快速排序算法 归并排序算法 希尔排序算法 基数排序算法

  • 希尔排序学习

    希尔排序希尔排序,也称递减增量排序算法,是插入排序的一种更高效的改进版本。但希尔排序是非稳定排序算法。希尔排序是基...

  • 排序算法-7---希尔排序

    排序算法-7---希尔排序 概念 希尔排序(Shellsort),也称递减增量排序算法,是一种典型的插入排序算法,...

  • 希尔排序

    希尔排序一种是很常见的排序算法,该算法在1959年由Donald Shell公布。 希尔排序的奥妙 1、希尔排序的...

网友评论

      本文标题:p163算法2.3希尔排序

      本文链接:https://www.haomeiwen.com/subject/pjzvaxtx.html