希尔排序Shell Sort是基于插入排序的一种改进,同样分成两部分,

第一部分,希尔排序介绍

第二部分,如何选取关键字,选取关键字是希尔排序的关键

第一块希尔排序介绍

准备待排数组[6 2 4 1 5 9]

首先需要选取关键字,例如关键是3和1(第一步分成三组,第二步分成一组),那么待排数组分成了以下三个虚拟组:

[6 1]一组

[2 5]二组

[4 9]三组

看仔细啊,不是临近的两个数字分组,而是3(分成了三组)的倍数的数字分成了一组,

就是每隔3个数取一个,每隔三个再取一个,这样取出来的数字放到一组,

把它们当成一组,但不实际分组,只是当成一组来看,所以上边的"组"实际上并不存在,只是为了说明分组关系

对以上三组分别进行插入排序变成下边这样

[1 6] [2 5] [4 9]

具体过程:

[6 1]6和1交换变成[1 6]

[2 5]2与5不动还是[2 5]

[4 9]4与9不动还是[4 9]

第一趟排序状态演示:

待排数组:[6 2 4 1 5 9]

排后数组:[1 2 4 6 5 9]

第二趟关键字取的是1,即每隔一个取一个组成新数组,实际上就是只有一组啦,隔一取一就全部取出来了嘛

此时待排数组为:[1 2 4 6 5 9]

直接对它进行插入排序

还记得插入排序怎么排不?复习一下

[1 2 4]都不用动,过程省略,到5的时候,将5取出,在前边的有序数组里找到适合它的位置插入,就是4后边,6前边

后边的也不用改,所以排序完毕

顺序输出结果:[1 2 4 5 6 9]

第二块希尔排序的关键是如何取关键字,因为其它内容与插入排序一样

那么如何选取关键字呢?就是分成三组,一组,这个分组的依据是什么呢?为什么不是二组,六组或者其它组嘞?

好的增量序列的共同特征:

① 最后一个增量必须为1

② 应该尽量避免序列中的值(尤其是相邻的值)互为倍数的情况

参见 http://baike.baidu.com/view/2217047.htm

这么关键的问题竟然没有一个公式,只给出了两个判定标准

好吧,一般10个待排数字的话,关键依次选取5 3 1即可,其它的情况只能自己判断了,然后看是否符合上述两条"好"的标准

就是说,这个关键的选择是没有规定的,怎么选都可以,仅一条,关键字要越来越小,直到1为止

后补:

增量的取值规则为第一次取总长度的一半,第二次取一半的一半,依次累推直到1为止!

以下C#代码实现供参考

static void shell_sort(int[] unsorted, int len){int group, i, j, temp;for (group = len / 2; group > 0; group /= 2){for (i = group; i < len; i++){for (j = i - group; j >= 0; j -= group){if (unsorted[j] > unsorted[j + group]){temp = unsorted[j];unsorted[j] = unsorted[j + group];unsorted[j + group] = temp;}}}}}static void Main(string[] args){int[] x = { 6, 2, 4, 1, 5, 9 };shell_sort(x, x.Length);foreach (var item in x){Console.WriteLine(item);}Console.ReadLine();}

希尔排序-Java二相关推荐

  1. 希尔排序java代码_希尔排序及希尔排序java代码

    由上图可看到希尔排序先约定一个间隔(图中是4),然后对0.4.8这个三个位置的数据进行插入排序,然后向右移一位对位置1.5.9进行插入排序按照此规律直到全部参与了排序.然后将间隔约定为4-1=3,然后 ...

  2. 希尔排序java写法_Java实现希尔排序

    华杰让我看了一道面试题:现有一段程序S,可以对任意n个数进行排序.如果现在需要对n^2个数进行排序,最少需要调用S多少次?(只允许调用S,不可以做别的操作). 看到了这个,我想试试希尔排序,就学学. ...

  3. 希尔排序--Java

    希尔排序 排序原理: 1.选定一个增量h,按照增长量h作为数据分组的依据,对数据进行分组 2.对分好组的每一组数据完成插入排序 3.减小增长量,最小减为1,重复第二步操作 其中,希尔排序确定增长量h的 ...

  4. 希尔排序java实现

    2019独角兽企业重金招聘Python工程师标准>>> 1.希尔排序的java实现 a.建议先理解清楚插入排序的原理再来理解: b.原理:将数据分成多分,再对各分进行插入排序 c.代 ...

  5. 排序-希尔排序-java

    将数据区分为成待定间隔的几个小区块,以插入排序法排完区块内的数据后在渐渐减少间隔的距离. 交换法: package paixu;import java.util.Arrays;// 希尔排序 publ ...

  6. 数据结构-希尔排序(Java实现)

    希尔排序 对插入排序的优化 因为当如果插入排序中最小的元素位于最后一位时,就需要不断的进行循环判断,直到第一位,非常影响效率 package datastructure.sort;/*@CreateT ...

  7. 数据结构之希尔排序------java实现

    //希尔排序//思想:需要分组,对每组用插入排序public void shellSort(int [] arr){int i,j,gap;int temp;gap=arr.length/2;whil ...

  8. 排序算法之希尔排序(Java)

    希尔排序  平均时间复杂度:O(nlogn)  不稳定的排序算法 v[0]与v[0+n/2]比较,v[1]与v[1+n/2]比较,v[2]与v[2+n/2]比较,小的放到前面,以此类推........ ...

  9. 希尔排序java写法_java高级排序之希尔排序

    希尔排序对于多达几千个数据项的,中等大小规模的数组排序表现良好,希尔排序不像快速排序和其它时间复杂度为o(n*logn)的排序算法那么快,因此,对非常大的文件排序,它不是最优选择,但是希尔排序比选择排 ...

最新文章

  1. word导入中的一个乱码
  2. 代码段、数据段、bss段
  3. Setting Up Hadoop NameNode High Availability
  4. Windows Server 2012 R2 或 2016 无法安装 .Net 3.5.1
  5. linux下面实时查看进程,内存以及cpu使用情况使用命令
  6. linux tomcat 进程杀掉_Linux下启动停止查看杀死Tomcat进程
  7. php 正则断言里面使用*+
  8. c语言编程伤心代码,C语言恶作剧代码:慎用,被打了不负责
  9. JQuery事件方法
  10. c++用msxml6.0解析xml
  11. 大数据最佳实践-hbase
  12. es 切换别名_Elasticsearch之别名
  13. 测试用例设计 通用原则
  14. P3324 [SDOI2015]星际战争
  15. 今天项目报错: No operations allowed after connection closed
  16. java log4j 热部署_nacos作为配置中心是否可以将log4j2.xml配置在nacos上面实现动态配置...
  17. 中山培训学校python
  18. 求10000里的阶乘C语言,最详细的注释,看不懂你来打我
  19. RS-232、RS-422、RS-485原理区别和联系!一看就懂
  20. 如何在c#代码中从itemtemplate的文本框中获取值?

热门文章

  1. 年度布道师颁奖|盘点2020年网易智企的布道先锋们
  2. 行业观察|智慧屏集中爆发,大屏市场能否迎来破局者?
  3. 限时免费报名丨网易新消费CXO论坛 - 深圳站
  4. 互联网1分钟 |0102
  5. 如何保证IM实时消息的“时序性”与“一致性”?
  6. Android Selector的简写
  7. Git常用操作命令----有备无患
  8. java mysql开发_Java数据库开发
  9. 【OS】期末总结复习
  10. Redis 命令--Redis集合(Set)