Python排序搜索基本算法之希尔排序实例分析

Python排序搜索基本算法之希尔排序实例分析,第1张

概述本文实例讲述了Python排序搜索基本算法希尔排序。分享给大家供大家参考,具体如下:

本文实例讲述了Python排序搜索基本算法之希尔排序。分享给大家供大家参考,具体如下:

希尔排序是插入排序的扩展,通过允许非相邻的元素进行交换来提高执行效率。希尔排序最关键的是选择步长,本程序选用knuth在1969年提出的步长序列:1 4 13 40 121 364 1093 3280 。。。后一个元素是前一个元素*3+1,非常方便选取,而且效率还不错。代码如下:

#-*- @R_301_5563@: UTF-8 -*-def shellsort(seq):  length=len(seq)  inc=0  while inc<=length/3:    inc=inc*3+1  print(inc)  while inc>=1:    for i in range(inc,length):      tmp=seq[i]      for j in range(i,-inc):        if tmp<seq[j-inc]:          seq[j]=seq[j-inc]        else:          j+=inc          break      seq[j-inc]=tmp    inc//=3if __name__=='__main__':  print("编程小技巧测试结果:")  seq=[8,6,4,9,7,3,2,-4,-100,99]  shellsort(seq)  print(seq)

运行结果:

PS:这里再为大家推荐一款关于排序的演示工具供大家参考:

在线动画演示插入/选择/冒泡/归并/希尔/快速排序算法过程工具:
http://tools.jb51.net/aideddesign/paixu_ys

更多关于Python相关内容感兴趣的读者可查看本站专题:《Python数据结构与算法教程》、《Python加密解密算法与技巧总结》、《Python编码 *** 作技巧总结》、《Python函数使用技巧总结》、《Python字符串 *** 作技巧汇总》及《Python入门与进阶经典教程》

希望本文所述对大家Python程序设计有所帮助。

总结

以上是内存溢出为你收集整理的Python排序搜索基本算法之希尔排序实例分析全部内容,希望文章能够帮你解决Python排序搜索基本算法之希尔排序实例分析所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1201094.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-04
下一篇 2022-06-04

发表评论

登录后才能评论

评论列表(0条)

保存