希尔排序

相当于把数据进行分组:然后进行排序。

这是在网上截屏的分析:

其实我也是刚学完这个不久,看完这个分析图以及还看了讲解,我依然不太懂,我就直接看代码,一步一步的跟着代码来推理一遍才懂了。

  /*
    * 希尔排序的第一种实现方法交换式,效率没有平移法好
    * 它的基本思想是:首先拿到一个数,然后与他一组的数据进行比较,
    * 如果小于前面的数就进行交换,每一组都要进行比较一次,有点像冒泡排序
    * */
    public static void shellSort(int[] arr){
        int gap = arr.length / 2; //间隙,一般最开始都是设为数组的中间,比如说10个数,这里就是5
        while(gap > 0){    //当间隙大于0,说明还可以分,这里就是5>0
            for(int i = gap; i < arr.length;i++){ //外层循环  第一个就是5
              for(int j = i-gap;j>=0;j-=gap){  //j = 0;
                  if(arr[j] > arr[j+gap]){  //arr[0] 跟arr[5]比,大于就交换,
                      int temp = arr[j];
                      arr[j] = arr[j+gap];
                      arr[j+gap] = temp;
                  }
              }//到这里就相当于第一组数据分好了,并且已经弄成有序
            }
            gap /= 2; // 这里再进行分组,变为了2
            }
    }

把代码对着上面的图分析一遍可能就理解一点了。

这里采用的是交换法,有点像冒泡排序的那味,我们进行优化。

public static void shellSort2(int[] arr){
        int gap = arr.length / 2;
        while(gap > 0){
            for(int i = gap; i < arr.length;i++){
                int temp = arr[i];
                int j = i;
                if(temp < arr[j-gap]){
                    /*
                    * 这里只能把两个条件写在一起,因为我们需要知道J的位置*/
                    for(; j-gap >=0 && temp < arr[j-gap] ;j -= gap){
                            arr[j] = arr[j - gap];
                    }
                        arr[j] = temp;
                }
            }
            gap /= 2;
        }
    }
希尔排序平移法
就是用一个临时变量,保存当前值,
用插入排序的思想,分有序表跟无序表
用的是选择排序那种思想,关于选择排序可以看看我后面写的博客。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值