首页IT科技希尔排序法是怎么排的(python希尔排序的用法)

希尔排序法是怎么排的(python希尔排序的用法)

时间2025-09-18 17:42:05分类IT科技浏览5511
导读:1、根据相邻元素进行排序,如果直接插入排序为步长为1,那么希尔排序就是先按步长为K插入排序。...

1                、根据相邻元素进行排序                ,如果直接插入排序为步长为1                        ,那么希尔排序就是先按步长为K插入排序                。

2                        、然后在步长K排序的基础上对步长m进行排序        ,K大于m                ,最后对步长1进行排序                        。

实例

defshell_sort(data_list): 思想:分治策略 使用for循环 length=len(data_list) space=length//2 whilespace>0: foriinrange(space,length):#默认第一个位置的元素是已排序区间                        ,因此下标从1开始 tmp=data_list[i]#待插入的数据 index=i forjinrange(i-space,-1,-space):#从已排序区间查找插入位置 iftmp<data_list[j]: data_list[j+space]=data_list[j]#元素向后移动        ,腾出插入位置 index=j#最后的j即为插入的位置 else: break data_list[index]=tmp#插入操作 print(data_list) space=space//2 returndata_list defshell_sort2(data_list): 思想:分治策略 使用while循环 length=len(data_list) space=length//2 whilespace>0: i=space whilei<length:#默认第一个位置的元素是已排序区间        ,因此下标从1开始 tmp=data_list[i]#待插入的数据 j=i whilej>=spaceanddata_list[j-space]>tmp:#从已排序区间查找插入位置 data_list[j]=data_list[j-space]#元素向后移动                        ,腾出插入位置 j-=space data_list[j]=tmp#插入操作 print(data_list) i+=1 space=space//2 returndata_list

以上就是python希尔排序的用法                ,希望对大家有所帮助        。更多Python学习指路:Python基础教程

创心域SEO版权声明:以上内容作者已申请原创保护,未经允许不得转载,侵权必究!授权事宜、对本内容有异议或投诉,敬请联系网站管理员,我们将尽快回复您,谢谢合作!

展开全文READ MORE
jetson camera(Jetson NX + yolov5 v5.0 + TensorRT加速+调用usb摄像头) wind11正式版(Win11正式版值得升吗?Win11正式版和Win10区别对比介绍)