前端leader-峰 2021-07-23 15:38 采纳率: 100%
浏览 32
已结题

希尔排序是建立在插入排序上的

写了一个插入排序,接着写希尔排序,分组之后的希尔排序就是进行好几次插入排序,这样子不是更费力了吗,数据结构与算法的一些简单的疑惑

  • 写回答

3条回答 默认 最新

  • 关注

    希尔排序不是插入排序哦,发个希尔排序的算法给你参考一下。

    package T5;
    
    public class ShellSort {
        int a[];
        public ShellSort() {
            a = new int[]{8,19,2,3,100,99,1000,888,-1,0};
            
            
            /*
             * 第一次是d=5组
             * (8,99),(19,1000),(2,888),(3,-1),(100,0)
             * 交换
             * (8,99),(19,1000),(2,888),(-1,3),(0,100)
             * 8,19,2,-1,0,99,1000,888,3,100
             * 第二次是d=2组
             * (8,2,0,1000,3),(19,-1,99,888,100)
             * 交换
             * (0,2,3,8,1000),(-1,19,99,100,888)
             * 0,-1,2,19,3,99,8,100,1000,888
             * 第3次是d=1时,其实只有一组,就是直接插入排序
             * 
             * 
             * */
        }
        public ShellSort(int a[]) {
            this.a = a;
        }
        
        public void shellSort(){
            int n = a.length;
            /*分组排序:分组的规则
             * 1.d = 数组长度/2;
             * 2.d = d/2;
             * 
             */
            for(int d=n/2;d>0;d/=2){
    //            System.out.println("d="+d+"时的排序情况");
                //插入排序
                for(int i=0;i<d;i++){ //增量为1时排序结束
                    //遍历所有子序
    //                System.out.print(i+"\t");
                    for(int j=i+d;j<n;j+=d){
    //                    System.out.print(j+"\t");
                        //对每个子序进行插入排序
                        int insertNode = a[j];
                        int k=j-d;
                        while(k>=i&& a[k]>insertNode){
                            a[k+d]=a[k];
                            k=k-d;
    //                        print();
                        }
                        a[k+d]=insertNode;
    //                    print();
                    }
    //                System.out.println("--------------------");
                    
                }
    //            print();
            }
            print();
        }
        public void print(){
            for (int e : a) {
                System.out.print(e+"\t");
            }
            System.out.println("");
        }
        public static void main(String[] args) {
            ShellSort shellSort = new ShellSort();
            System.out.println("排序前");
            shellSort.print();
            shellSort.shellSort();
    //        shellSort.print();
        }
    }
    
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 10月30日
  • 已采纳回答 10月22日
  • 创建了问题 7月23日

悬赏问题

  • ¥15 delta降尺度计算的一些细节,有偿
  • ¥15 Arduino红外遥控代码有问题
  • ¥15 数值计算离散正交多项式
  • ¥30 数值计算均差系数编程
  • ¥15 redis-full-check比较 两个集群的数据出错
  • ¥15 Matlab编程问题
  • ¥15 训练的多模态特征融合模型准确度很低怎么办
  • ¥15 kylin启动报错log4j类冲突
  • ¥15 超声波模块测距控制点灯,灯的闪烁很不稳定,经过调试发现测的距离偏大
  • ¥15 import arcpy出现importing _arcgisscripting 找不到相关程序