位置: 编程技术 - 正文

python编程实现希尔排序(编写python)

编辑:rootadmin

推荐整理分享python编程实现希尔排序(编写python),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:编程用python,编程python怎么用,python中编写程序,python编写程序,python编写程序,用python编写程序,编写python,用python编写程序,内容如对您有帮助,希望把文章链接给更多的朋友!

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

  如果当数据是”5, 4, 3, 2, 1“的时候,此时我们将“无序块”中的记录插入到“有序块”时,估计俺们要崩盘,每次插入都要移动位置,此时插入排序的效率可想而知。

  shell根据这个弱点进行了算法改进,融入了一种叫做“缩小增量排序法”的思想,其实也蛮简单的,不过有点注意的就是:

增量不是乱取,而是有规律可循的。

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

首先要明确一下增量的取法(这里图片是copy别人博客的,增量是奇数,我下面的编程用的是偶数):

第一次增量的取法为: d=count/2;

第二次增量的取法为: d=(count/2)/2;

最后一直到: d=1;

好,注意看图了,第一趟的增量d1=5, 将个待排记录分为5个子序列,分别进行直接插入排序,结果为(, , , , , , , , , )

第二趟的增量d2=3, 将个待排记录分为3个子序列,分别进行直接插入排序,结果为(, , , , , , , , , )

第三趟的增量d3=1, 对整个序列进行直接插入排序,最后结果为(, , , , , , , , , )

重点来了。当增量减小到1时,此时序列已基本有序,希尔排序的最后一趟就是接近最好情况的直接插入排序。可将前面各趟的"宏观"调整看成是最后一趟的预处理,比只做一次直接插入排序效率更高。

本人是学python的,今天用python实现了希尔排序。

输出:

python编程实现希尔排序(编写python)

>: [, , , , , , , , , 4]>>: [, , , , 4, , , , , ]>>: [4, , , , , , , , , ]>>: [4, , , , , , , , , ]

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

插入排序,即是对上图三个黄色框中的数进行插入排序。举个例子:,,,

直接看,<, 不用移动。接着看,<,那么后移,数据变为[,,,],接着比较<, 那么替换,变成[,,,]。其它同理,略。

这里有个问题,比如第二个黄色框[,4,],4<, 那往后移,接着4就替换第一个,数据变成[4,,],但是计算机怎么知道4就是在第一个啊&#;&#;

我的做法是,先找出[,4,]第一个数的下标,在这个例子中的下标为1。当要插入的数的下标大于第一个下标1时,才可以往后移,前一个数不可以往后移有两种情况,一种是前面有数据,且小于要插入的数,那你只能插在它后面。另一种,很重要,当要插入数比前面所有数都小时,那插入数肯定是放在第一个,此时要插入数的下标=第一个数的下标。(这段话,感觉初学者应该不大懂……)

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

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

时间复杂度:

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

稳定性: 不稳定

希尔排序效果:

参考资料: 编程是我自己实现的。建议Debug看看运行过程

c++中八大排序算法

视觉直观感受若干常用排序算法

C#七大经典排序算法系列(下)

1.非系统的学习也是在浪费时间 2.做一个会欣赏美,懂艺术,会艺术的技术人

标签: 编写python

本文链接地址:https://www.jiuchutong.com/biancheng/375506.html 转载请保留说明!

上一篇:python实现解数独程序代码(python 数独破解器)

下一篇:python常见排序算法基础教程(排序方法python)

  • 综合收益总额与什么有关
  • 房产税的纳税义务人是征税范围内房屋产权所有人
  • 收入和费用类科目一般设置为什么辅助核算
  • 存货成本核算方法有哪些
  • 编制初始计量有什么要求
  • 2019年地方各项基金费申报表填写错误要交滞纳金吗
  • 特许权使用费增值税征收品目
  • 分配本月职工薪酬会计分录该怎么做合适?
  • 季节性停工折旧吗
  • 应付账款借方余额在资产负债表中怎么列示
  • 公司闲置房租出去违法吗
  • 分配股利需要缴纳个税吗
  • 公司车辆计提是含税还是不含税?
  • 专票抵扣是税额吗
  • 房地产不可销售的物业有哪些
  • 营改增后房地产企业增值税税收筹划存在问题
  • 普通增值税 税点
  • 普票冲红需要收回全部联次吗
  • 符合免税条件的一般纳税人开具发票税率
  • 下岗职工能享受什么待遇
  • 退进项税留抵是什么意思
  • 工资年终奖金扣多少税
  • 领用工程物资用于在建工程的进项税抵扣问题
  • 这个月只开了销项负数怎么办
  • 稽查查补税款怎么计算企业所得税
  • 福利费计提包括奖金吗
  • windows10如何开机启动软件
  • 进项发票没认证可以开红字申请单吗
  • 苹果电脑进入安全模式按什么键
  • 买二手房避税
  • 拍到国际空间站过境
  • 上传图片照片
  • uniapp webgl
  • 向银行借入长期借款200000元,存入银行
  • php dirname函数
  • 现金溢余和短缺的会计分录
  • 电汇收款的会计分录
  • 工业企业成本核算的一般程序包括下列的
  • php5.2漏洞
  • 织梦配置文件
  • 织梦文章内容图片大全
  • java变量初始化的两种方式
  • 长期待摊费用是什么意思
  • 企业应付债券增加说明了什么
  • 私车公用的汽油费计入哪个科目
  • 新会计准则其他收益核算内容
  • 符合规定的国内旅客运输发票可以作为扣税凭证吗
  • 个人所得税能说明什么
  • 高新企业必须做加计扣除吗
  • 存货抵债如何做分录
  • 水泥销售技巧
  • 出口退税转免税怎么写个说明
  • 辞退补偿金入什么科目
  • 什么是发票抬头信息
  • 开具旧税号也能认证成功
  • windows提示无法完成更新
  • 联想昭阳k41笔记本
  • optimize error by column count
  • win7系统为什么玩不了游戏
  • win7系统注册表文件损坏无法开机怎么修复
  • windows xp iis安装
  • linux指令系统
  • win10更新补丁导致打印机
  • linux 如何查看端口
  • win7玩英雄联盟卡顿怎么解决
  • win7如何显示文件扩展
  • linux 清除垃圾
  • cocos2d-x教程
  • android开发环境是什么
  • 认识 认知
  • redis开机自动启动linux
  • Lesson02_05 头元素
  • glsl编译
  • Python生成随机数
  • js实现返回顶部
  • Unity3d C# HttpWebRequest 异步下载文件
  • jQuery+ajax+asp.net获取Json值的方法
  • 企业滞纳金怎么算 计算公式
  • 车辆购置税是国家收还是地方收
  • 安徽省地方税务局刘利庆
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设