#希尔排序
# 平均时间复杂度 O(n^1.3)
# 最好情况 O(n)
# 最坏情况 O(n^2)
# 空间复杂度 O(1)
# 算法描述:
# (1) 选择一个增量序列t1,t2,…,tk,其中ti>tj,tk=1;
# (2) 按增量序列个数k,对序列进行k 趟排序;
# (3) 每趟排序,根据对应的增量ti,将待排序列分割成若干长度为m 的子序列,分别对各子表进行直接插入排序。
# 仅增量因子为1 时,整个序列作为一个表来处理,表长度即为整个序列的长度。
def Shell_sort(lists):
## 获取lists的总长度
count = len(lists)
#初始步长
step = round(count / 2) #四舍五入取整
while step > 0: # 步长: 3, 2, 1
for i in range(step, count):
while(i >= step and lists[i] < lists[i-step]):
lists[i], lists[i-step] = lists[i-step], lists[i]
i -= step
step = round(step / 2)
#print(lists)
return lists
if __name__ == "__main__":
lists = [9, 3, 5, 2, 7, 4]
print(Shell_sort(lists))
希尔排序
最新推荐文章于 2025-02-19 20:29:40 发布