希尔排序:

观察一下”插入排序“:其实不难发现她有个缺点:

  如果当数据是”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实现了希尔排序。

 1 def ShellInsetSort(array, len_array, dk):  # 直接插入排序
 2     for i in range(dk, len_array):  # 从下标为dk的数进行插入排序
 3         position = i
 4         current_val = array[position]  # 要插入的数
 5
 6         index = i
 7         j = int(index / dk)  # index与dk的商
 8         index = index - j * dk
 9
10         # while True:  # 找到第一个的下标,在增量为dk中,第一个的下标index必然 0<=index<dk
11         #     index = index - dk
12         #     if 0<=index and index <dk:
13         #         break
14
15
16         # position>index,要插入的数的下标必须得大于第一个下标
17         while position > index and current_val < array[position-dk]:
18             array[position] = array[position-dk]  # 往后移动
19             position = position-dk
20         else:
21             array[position] = current_val
22
23
24
25 def ShellSort(array, len_array):  # 希尔排序
26     dk = int(len_array/2)  # 增量
27     while(dk >= 1):
28         ShellInsetSort(array, len_array, dk)
29         print(">>:",array)
30         dk = int(dk/2)
31
32 if __name__ == "__main__":
33     array = [49, 38, 65, 97, 76, 13, 27, 49, 55, 4]
34     print(">:", array)
35     ShellSort(array, len(array))

输出:

>: [49, 38, 65, 97, 76, 13, 27, 49, 55, 4]
>>: [13, 27, 49, 55, 4, 49, 38, 65, 97, 76]
>>: [4, 27, 13, 49, 38, 55, 49, 65, 97, 76]
>>: [4, 13, 27, 38, 49, 49, 55, 65, 76, 97]

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

插入排序,即是对上图三个黄色框中的数进行插入排序。举个例子: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时,才可以往后移,前一个数不可以往后移有两种情况,一种是前面有数据,且小于要插入的数,那你只能插在它后面。另一种,很重要,当要插入数比前面所有数都小时,那插入数肯定是放在第一个,此时要插入数的下标=第一个数的下标。(这段话,感觉初学者应该不大懂……)

为了找到第一个数的下标,最开始想的是用循环,一直到最前面:

        while True:  # 找到第一个的下标,在增量为dk中,第一个的下标index必然 0<=index<dkindex = index - dkif 0<=index and index <dk:break

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

        j = int(index / dk)  # index与dk的商index = index - j * dk

时间复杂度:

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

稳定性: 不稳定

希尔排序效果:

参考资料: 编程是我自己实现的。建议Debug看看运行过程
http://blog.csdn.net/hguisu/article/details/7776068#t2

http://www.blogjava.net/todayx-org/archive/2012/01/08/368091.html

http://www.cnblogs.com/huangxincheng/archive/2011/11/20/2255695.html

转载于:https://www.cnblogs.com/0zcl/p/6680652.html

python实现希尔排序(已编程实现)相关推荐

  1. 希尔排序不稳定例子_Python实现希尔排序(已编程实现)

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

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

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

  3. python实现希尔排序_希尔排序算法的python实现

    下面是编程之家 jb51.cc 通过网络收集整理的代码片段. 编程之家小编现在分享给大家,也给大家做个参考. def shellSort(items): inc = len(items) / 2 wh ...

  4. python实现希尔排序算法_排序算法总结(冒泡排序、直接插入排序、希尔排序)(python实现)...

    其实本文叫排序算法总结有点过了,只是用python实现了一遍.本文都是参照一篇csdn博客<数据结构排序算法>,里面详细介绍每种排序算法的原理,并给出了C++的实现,再次膜拜. # -*- ...

  5. 用python写希尔排序_python希尔排序介绍(实例)

    希尔排序介绍 希尔排序(Shell Sort)是插入排序的一种.也称缩小增量排序,是直接插入排序算法的一种更高效的改进版本,该方法的基本思想是:先将整个待排元素序列分割成若干个子序列(由相隔某个&qu ...

  6. python实现希尔排序

    与插入排序的思想一致,插入排序是一个,希尔排序是多个插入排序! # @File: shell_sortimport randomdef insert_sort_gap(li, d):for i in ...

  7. 用Python实现希尔排序

    希尔排序 希尔排序(Shell Sort)是插⼊排序的⼀种.也称缩⼩增量排序,是直接插⼊排序算法的⼀种更⾼效的改进版本.希尔排序是⾮稳定排序算法.该⽅法因DL.Shell于1959年提出⽽得名. 希尔 ...

  8. python实现希尔排序算法_python实现希尔排序算法

    希尔排序是插入排序的一种又称"缩小增量排序",是直接插入排序算法的一种更高效的改进版本.希尔排序是非稳定排序算法. 希尔排序是把记录按下标的一定增量分组,对每组使用直接插入排序算法 ...

  9. Python实现希尔排序算法

    def shell_sort(alist):"""希尔排序又叫缩小增量排序,是插入排序的一种"""n = len(alist)gap = n ...

  10. 希尔排序python实现

    希尔排序python实现 希尔排序是直接插入排序的加强版,也称为减小增量排序.以从小到大排序为例进行简要分析. 算法思想 希尔排序的排序思想在先将原序列划分成若干个子序列,其中划分的依据为按照间隔ga ...

最新文章

  1. 回归算法分类,常用回归算法解析
  2. rabbitmq 限制速度_=(:) RabbitMQ详解
  3. 基于VLC的播放器开发
  4. 在BackTrack下基于MS08-067漏洞的渗透
  5. mysql流量控制_Daloradius限制上网流量
  6. mysql中建立text_mysql中text
  7. 2021快手电商数据报告
  8. mysql less6教程_Sqli labs系列-less-56 报错注入法(上)
  9. 笔记-Microsoft SQL Server 2008技术内幕:T-SQL语言基础-02 单表查询
  10. 对I2C总线的时钟同步和总线仲裁的深入理解
  11. Arthur J.Riel的61条面向对象设计的经验原则[ZT]
  12. android 蓝牙连接obd,Android蓝牙连接汽车OBD设备
  13. Mybatis-no getter for property named 'col_name' in 'class com.xxx.onebean'
  14. Reza Zafarani经典教材-《社交媒体挖掘》PDF+随书课件打包分享
  15. SAP SD pricing condition技术在系统里的一些练习
  16. Linux驱动开发(十四)---USB驱动开发学习(键盘+鼠标)
  17. springboot jedis配置以及集群(第三篇) ubuntu16实现redis集群
  18. 【CSS】calc 函数(动态计算长度值)
  19. 阿里国际站用户增长技术探索与实践
  20. PTA天天练(大于身高的平均值 )

热门文章

  1. 往事如烟,残阳如血......——逝去的背影(五)
  2. 每一次结束只是一次新的起点,深有体会。
  3. 深度学习TF—7.卷积神经网络CNN
  4. numpy-np.Inf
  5. 机器学习2-Logistic回归
  6. 网卡驱动程序问题---电脑自己没操作,突然连不上网
  7. 在vue中使用javascript动态修改字符串中某段文字的颜色
  8. Python基本的数据结构-序列
  9. 不愧是我,短短10分钟就为公司省下了几万块 ( ー̀◡ー́ )
  10. 每周送新书:Android软件安全、深入浅出Istio、软件架构设计