希尔排序--python

Posted 落后就要挨打

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了希尔排序--python相关的知识,希望对你有一定的参考价值。

 1 import random
 2 import time
 3 
 4 # 插入排序
 5 def insertion_sort(arr, step):
 6     for i in range(step, len(arr)):
 7         for j in range(i, step - 1, -step):
 8             if arr[j] < arr[j-step]:
 9                 arr[j], arr[j-step] = arr[j-step], arr[j]
10             else:
11                 break
12 
13 # 希尔排序:插入排序算法的优化算法
14 def shell_sort(arr):
15     length = len(arr)
16     step = 1
17 
18     while step < length // 3:
19         step = 3 * step + 1
20 
21     while step >= 1:
22         insertion_sort(arr, step)
23         step = step // 3
24 
25 
26 if __name__ == __main__:
27     arr = [random.randint(0, 1000000) for _ in range(5000)]
28     print(待排序数组大小:, len(arr))
29     start = time.time()
30     shell_sort(arr)
31     end = time.time()
32     print(用时:, end - start)

 

以上是关于希尔排序--python的主要内容,如果未能解决你的问题,请参考以下文章

使用python实现希尔计数基数排序

python排序-希尔排序

插入排序_希尔排序(python)

希尔排序之python

Python|插入排序之希尔排序

在路上---学习篇Python 数据结构和算法 --希尔排序归并排序