谢尔排序—Python实现

阅读: 评论:0

谢尔排序—Python实现

谢尔排序—Python实现

谢尔排序

我们注意到插入排序的对比次数,在最好的情况下是O(n),这种情况发生在列表是已有序的情况下,实现上,列表越接近有序,插入排序的比对次数就越少。

对这个情况入手,谢尔排序以插入排序为基础,对无序表进行“间隔”划分子列表,每个子列表执行插入排序

间隔为3的子列表,子列表分别插入排序后的整体状况更接近有序


最后一趟是标准的插入排序,但由于前面几趟已经将列表处理到接近有序,这一趟仅需要少数几次移动即可完成

子列表的间隔一般从n/2开始,每趟倍增:n/4,n/8……直到1


代码

def shellSort(alist):sublistount=len(alist)//2while sublistount>0:for startposition in range(sublistount):gapInsertionSort(alist,startposition,sublistount)print("After increments of size",sublistount,"The list is",alist)sublistount=sublistount//2
def gapInsertionSort(alist,start,gap):for i in range(start+gap,len(alist),gap):current=alist[i]position=iwhile position>=gap and alist[position-gap]>current:alist[position]=alist[position-gap]position=position-gapalist[position]=currentalist=[52,312,54,7,3,2,56,34,65]
shellSort(alist)
print(alist)

本文发布于:2024-01-30 01:15:21,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/170654852418190.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:谢尔   Python
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23