作者:小小程序员
链接:https://zhuanlan.zhihu.com/p/65334039
来源:知乎
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

观察一下”插入排序“:其实不难发现她有个缺点:
如果当数据是”5, 4, 3, 2, 1“的时候,此时我们将“无序块”中的记录插入到“有序块”时,估计俺们要崩盘,
每次插入都要移动位置,此时插入排序的效率可想而知。
shell根据这个弱点进行了算法改进,融入了一种叫做“缩小增量排序法”的思想,其实也蛮简单的,不过有点注意的就是:
增量不是乱取,而是有规律可循的。

希尔排序时效分析很难,关键码的比较次数与记录移动次数依赖于增量因子序列d的选取,特定情况下可以准确估算出关键码的比较次数和记录的移动次数。目前还没有人给出选取最好的增量因子序列的方法。增量因子序列可以有各种取法,有取奇数的,也有取质数的,但需要注意:增量因子中除1 外没有公因子,且最后一个增量因子必须为1。希尔排序方法是一个不稳定的排序方法。
首先要明确一下增量的取法(这里图片是copy别人博客的,增量是奇数,我下面的编程用的是偶数):

  • 第一次增量的取法为: d=count/2;
  • 第二次增量的取法为: d=(count/2)/2;
  • 最后一直到: d=1;

好,注意看图了,第一趟的增量d1=5, 将10个待排记录分为5个子序列,分别进行直接插入排序,结果为(13, 27, 49, 55, 04, 49, 38, 65, 97, 76)
第二趟的增量d2=3, 将10个待排记录分为3个子序列,分别进行直接插入排序,结果为(13, 04,49, 38, 27, 49, 55, 65, 97, 76)
第三趟的增量d3=1, 对整个序列进行直接插入排序,最后结果为(04, 13, 27, 38, 49, 49, 55, 65, 76, 97)
重点来了。当增量减小到1时,此时序列已基本有序,希尔排序的最后一趟就是接近最好情况的直接插入排序。可将前面各趟的"宏观"调整看成是最后一趟的预处理,比只做一次直接插入排序效率更高。
本人是学python的,今天用python实现了希尔排序。

输出:

首先你得先会插入排序,不会你必然看不懂。

插入排序,即是对上图三个黄色框中的数进行插入排序。举个例子:13,55,38,76
直接看55,55<13, 不用移动。接着看38,38<55,那么55后移,数据变为[13,55,55,76],接着比较13<38, 那么38替换55,变成[13,38,55,76]。其它同理,略。
这里有个问题,比如第二个黄色框[27,4,65],4<27, 那27往后移,接着4就替换第一个,数据变成[4,27,65],但是计算机怎么知道4就是在第一个啊??
我的做法是,先找出[27,4,65]第一个数的下标,在这个例子中27的下标为1。当要插入的数的下标大于第一个下标1时,才可以往后移,前一个数不可以往后移有两种情况,一种是前面有数据,且小于要插入的数,那你只能插在它后面。另一种,很重要,当要插入数比前面所有数都小时,那插入数肯定是放在第一个,此时要插入数的下标=第一个数的下标。(这段话,感觉初学者应该不大懂……)
为了找到第一个数的下标,最开始想的是用循环,一直到最前面:

在Debug时,发现用循环太浪费时间了,特别是当增量d=1时,直接插入排序为了插入列表最后一个数,得循环减1,直到第一个数的下标,后来我学聪明了,用下面的方法:

时间复杂度:
希尔排序的时间复杂度是所取增量序列的函数,尚难准确分析。有文献指出,当增量序列为d[k]=2^(t-k+1)时,希尔排序的时间复杂度为O(n^1.5), 其中t为排序趟数。
稳定性: 不稳定
希尔排序效果:

转自:python实现希尔排序(已编程实现)

希尔排序不稳定例子_Python实现希尔排序(已编程实现)相关推荐

  1. python中的sort排序加换行_python中sort()排序的方法

    python中sort()排序的方法 发布时间:2020-09-01 10:57:52 来源:亿速云 阅读:110 作者:小新 这篇文章主要介绍了python中sort()排序的方法,具有一定借鉴价值 ...

  2. python中排序的函数_Python中sorted()排序函数

    语法: sorted(iterable, key=None, reverse=False) *iterable:可迭代的对象 *key:用来排序的元素,可以通过函数指定 *reverse:排序规则,r ...

  3. 希尔排序增量怎么确定_Python实现希尔排序(已编程实现)

    希尔排序: 观察一下"插入排序":其实不难发现她有个缺点: 如果当数据是"5, 4, 3, 2, 1"的时候,此时我们将"无序块"中的记录插 ...

  4. python希尔排序的优缺点_Python排序搜索基本算法之希尔排序实例分析

    本文实例讲述了Python排序搜索基本算法之希尔排序.分享给大家供大家参考,具体如下: 希尔排序是插入排序的扩展,通过允许非相邻的元素进行交换来提高执行效率.希尔排序最关键的是选择步长,本程序选用Kn ...

  5. 教你随心所欲的操作希尔排序,而不是死记希尔模板。它的精髓,你知道吗?

    希尔排序是一种效率很高,很重要的排序,在了解希尔排序之前我们先要了解一下直接插入排序以及它的思想.在这里讲直接插入排序的时候我会把它和希尔排序进行高度的统一,以便于大家的对比学习. 直接插入排序 先来 ...

  6. 【八大排序详解~C语言版】直接插入排序-希尔排序- 直接选择排序-堆排序-冒泡排序-快速排序-归并排序-计数排序

    八大排序 1.直接插入排序 2.希尔排序 3.直接选择排序 直接选择排序改进 4.堆排序 1.建堆 2.利用堆删除思想来进行排序 5.冒泡排序 6.快速排序 递归实现 非递归实现 7.归并排序 递归实 ...

  7. 【Java】5大排序算法总结(插入排序+希尔排序+选择排序+堆排序+冒泡排序)

    快速导航: 1. 稳定性 2 . 插入排序 3. 希尔排序 4. 选择排序 5. 堆排序 6 冒泡排序 1. 稳定性 两个相等的数据,如果经过排序后,排序算法能保证其相对位置不发生变化,则我们称该算法 ...

  8. 排序上---(排序概念,常见排序算法,直接插入,希尔排序,直接选择排序,堆排序)

    排序的概念 排序:所谓排序,就是使一串记录,按照其中的某个或某些关键字的大小,递增或递减的排列起来的操作. 稳定性:假定在待排序的记录序列中,存在多个具有相同的关键字的记录,若经过排序,这些记录的相对 ...

  9. 希尔排序是一种稳定的排序算法_十大经典排序算法——希尔排序

    vs code ppt c++/java 目录 1.1.排序分类 1.2.排序的定义: 对一序列对象根据某个关键字进行排序. 1.3.术语说明 稳定:如果a原本在b前面,而a=b,排序之后a仍然在b的 ...

最新文章

  1. 【交互】Omkar and the Meaning of Life(CF-1586D)
  2. pytorch卷积神经网络_知识干货-动手学深度学习(pytorch)-06 卷积神经网络基础
  3. java连接mysql表格_java中表格连接数据库
  4. 20211010 PHP笔记
  5. ADO.NET数据访问模式
  6. Bus Hound错误提示解释
  7. 【Bat】内外网切换
  8. Ubuntu20.04安装有道词典 + 卸载
  9. python语言保留字有true吗_python语言的保留字
  10. pid参数设置要点即口诀
  11. CSS绝对定位使用left:50%实现水平居中偏左问题
  12. 免费下载QFP器件手工焊接指南
  13. 你好,CSDN,我来了。我想在这里记录我的学习和分享知识教程
  14. Unity 3D模型展示之UI布局
  15. 数据挖据---机器学习平台之H2O架构/接口/实践
  16. WT品牌语音芯片、功放芯片—让人机交互更简单,让电子世界更美好
  17. pubg体验服服务器维护,简单1招,教你快速获得《Pubg Mobile》体验服“邀请码”!...
  18. 云原生:打造「阿拉丁神灯式」应用厨房
  19. laravel阿里SDK对接
  20. 创建GIT项目,并初始化上传项目代码

热门文章

  1. 红帽7编译安装mysql_精通RHEL7编译安装mysql-5.5.32
  2. 亚马逊分类目录_新版亚马逊分类目录v2.4程序源码官方分享下载
  3. php gpg,使用 gpg 验证 php
  4. mysql登录报错error1045,mysql创建登录报错ERROR1045(28000)
  5. java 增 删 查 改_如何对java链表进行增、删、查、改操作
  6. oracle10G分区的创建与维护Oracle分区表和本地索引
  7. 魔力宝贝服务器修改技能经验,传说中的技能及修改建议
  8. Swagger 属性名 FastJson支持,@ApiModelProperty无法序列化
  9. Jsp+Servlet +Mysql实现的新闻发布管理系统
  10. 基于JAVA+SpringMVC+Mybatis+MYSQL的外卖点餐系统