排序之希尔排序

2020-12-13 02:52

阅读:427

标签:err   ++   ring   iss   ide   pack   希尔   code   integer   

package ShellSort;

import chooseSort.Example;

/**
 * 希尔排序
 * 思想:插入排序的变步长扩展版。以h..1为步长,将数组分为若干组,然后进行插入排序
 * 解决了插入排序交换次数过多的问题。
 */
public class ShellSort extends Example {

    @Override
    public void sort(Comparable[] a) {
        int h = 1;
        int n = a.length;
        while(h//hwhile(h>=1){  //遍历所有步长,最后一次步长为1
            //步长为h的插入排序
            for(int i=h;i){
                for(int j=i;j>h-1&&less(a[j],a[j-h]);j-=h){
                    exch(a,j,j-h);
                }
            }
            h=h/3;
        }
    }

//    /**
//     * 测试用例
//     * @param args
//     */
//    public static void main(String[] args) {
//        Integer[] a = new Integer[]{34,2,5,4,45,6,22};
//        ShellSort sort = new ShellSort();
//        sort.sort(a);
//        show(a);
//        System.out.println(isSorted(a));
//    }
}

 

排序之希尔排序

标签:err   ++   ring   iss   ide   pack   希尔   code   integer   

原文地址:https://www.cnblogs.com/youzoulalala/p/11058892.html


评论


亲,登录后才可以留言!