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

如果当数据是”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实现了希尔排序。
def ShellInsetSort(array, len_array, dk): # 直接插入排序
for i in range(dk, len_array): # 从下标为dk的数进行插入排序
position = i
current_val = array[position] # 要插入的数
index = i
j = int(index / dk) # index与dk的商
index = index - j * dk
# while True: # 找到第一个的下标,在增量为dk中,第一个的下标index必然 0<=index<dk
# index = index - dk
# if 0<=index and index <dk:
# break
# position>index,要插入的数的下标必须得大于第一个下标
while position > index and current_val < array[position-dk]:
array[position] = array[position-dk] # 往后移动
position = position-dk
else:
array[position] = current_val
def ShellSort(array, len_array): # 希尔排序
dk = int(len_array/2) # 增量
while(dk >= 1):
ShellInsetSort(array, len_array, dk)
print(">>:",array)
dk = int(dk/2)
if __name__ == "__main__":
array = [49, 38, 65, 97, 76, 13, 27, 49, 55, 4]
print(">:", array)
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<dk index = index - dk if 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看看运行过程
c++中八大排序算法
视觉直观感受若干常用排序算法
C#七大经典排序算法系列(下)
1.非系统的学习也是在浪费时间 2.做一个会欣赏美,懂艺术,会艺术的技术人
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# python
# 希尔排序
# 使用python实现希尔、计数、基数基础排序的代码
# Python排序搜索基本算法之希尔排序实例分析
# Python实现希尔排序算法的原理与用法实例分析
# python实现的希尔排序算法实例
# python实现希尔密码加密的示例代码
# 希尔
# 第一个
# 的是
# 有个
# 后移
# 不稳定
# 是一个
# 以往
# 是在
# 来了
# 也有
# 还没
# 放在
# 在这个
# 是有
# 最好的
# 都要
# 很难
# 那你
# 人是
相关文章:
常州企业建站如何选择最佳模板?
Python如何创建带属性的XML节点
建站主机数据库如何配置才能提升网站性能?
公司网站制作需要多少钱,找人做公司网站需要多少钱?
如何通过虚拟机搭建网站?详细步骤解析
网站制作说明怎么写,简述网页设计的流程并说明原因?
建站org新手必看:2024最新搭建流程与模板选择技巧
早安海报制作网站推荐大全,企业早安海报怎么每天更换?
高性能网站服务器配置指南:安全稳定与高效建站核心方案
如何确认建站备案号应放置的具体位置?
如何在万网自助建站中设置域名及备案?
Java解压缩zip - 解压缩多个文件或文件夹实例
javascript中的try catch异常捕获机制用法分析
定制建站哪家更专业可靠?推荐榜单揭晓
定制建站流程解析:需求评估与SEO优化功能开发指南
网站制作员失业,怎样查看自己网站的注册者?
网站制作多少钱一个,建一个论坛网站大约需要多少钱?
如何在景安服务器上快速搭建个人网站?
如何通过虚拟主机快速完成网站搭建?
如何高效完成自助建站业务培训?
如何用y主机助手快速搭建网站?
建站之星手机一键生成:多端自适应+小程序开发快速建站指南
如何快速生成ASP一键建站模板并优化安全性?
c# 在高并发下使用反射发射(Reflection.Emit)的性能
测试制作网站有哪些,测试性取向的权威测试或者网站?
微网站制作教程,不会写代码,不会编程,怎么样建自己的网站?
如何正确下载安装西数主机建站助手?
c++ stringstream用法详解_c++字符串与数字转换利器
零服务器AI建站解决方案:快速部署与云端平台低成本实践
,柠檬视频怎样兑换vip?
图片制作网站免费软件,有没有免费的网站或软件可以将图片批量转为A4大小的pdf?
开心动漫网站制作软件下载,十分开心动画为何停播?
教育培训网站制作流程,请问edu教育网站的域名怎么申请?
文字头像制作网站推荐软件,醒图能自动配文字吗?
建站之星Pro快速搭建教程:模板选择与功能配置指南
兔展官网 在线制作,怎样制作微信请帖?
制作农业网站的软件,比较好的农业网站推荐一下?
建站之星五站合一营销型网站搭建攻略,流量入口全覆盖优化指南
mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界?
如何通过IIS搭建网站并配置访问权限?
如何在万网开始建站?分步指南解析
高端建站三要素:定制模板、企业官网与响应式设计优化
公司网站建设制作费用,想建设一个属于自己的企业网站,该如何去做?
如何选择高效稳定的ISP建站解决方案?
如何快速上传自定义模板至建站之星?
代购小票制作网站有哪些,购物小票的简要说明?
C#怎么使用委托和事件 C# delegate与event编程方法
北京制作网站的公司,北京铁路集团官方网站?
广东企业建站网站优化与SEO营销核心策略指南
如何获取PHP WAP自助建站系统源码?
*请认真填写需求信息,我们会在24小时内与您取得联系。