Python算法——希尔排序

2023-11-30 19:35:49 浏览数 (2)

希尔排序(Shell Sort)是一种改进的插入排序算法,它通过将数组分成多个子数组,并对每个子数组进行插入排序,逐渐减小子数组的间隔,最终完成排序。希尔排序是一种高效的排序算法,特别适用于中等大小的数据集。本文将详细介绍希尔排序的工作原理和Python实现。

希尔排序的工作原理

希尔排序的基本思想是:
  1. 选择一个间隔序列(gap sequence),将数组分成多个子数组,每个子数组包含距离为间隔的元素。
  2. 对每个子数组进行插入排序,逐渐减小间隔。 重复步骤 1 和 2,直到间隔为 1,完成最后一次插入排序。
  3. 希尔排序的关键在于如何选择间隔序列,通常采用的是希尔建议的间隔序列(1, 4, 10, 23, 57…)或者使用其他自定义的序列。
下面是一个示例,演示希尔排序的过程:

原始数组:[12, 34, 54, 2, 3]

  1. 选择间隔序列,例如 [2, 1]。
  2. 第一轮排序,将间隔为 2 的元素分成两组,分别进行插入排序。
    • 子数组 1:[12, 54, 3],排序后:[3, 12, 54]
    • 子数组 2:[34, 2],排序后:[2, 34]
  3. 第二轮排序,将间隔为 1 的元素进行插入排序,得到最终排序结果。
Python实现希尔排序

下面是Python中的希尔排序实现:

代码语言:javascript复制
def shell_sort(arr):
    n = len(arr)
    gap = n // 2  # 初始间隔

    while gap > 0:
        for i in range(gap, n):
            temp = arr[i]
            j = i

            while j >= gap and arr[j - gap] > temp:
                arr[j] = arr[j - gap]
                j -= gap

            arr[j] = temp

        gap //= 2  # 减小间隔
  • arr 是待排序的数组。
  • 初始间隔 gap 通常为数组长度的一半,然后逐渐减小。
  • 内层循环对每个子数组进行插入排序,根据当前间隔 gap,对距离为 gap 的元素进行排序。
示例代码

下面是一个使用Python进行希尔排序的示例代码:

代码语言:javascript复制
def shell_sort(arr):
    n = len(arr)
    gap = n // 2

    while gap > 0:
        for i in range(gap, n):
            temp = arr[i]
            j = i

            while j >= gap and arr[j - gap] > temp:
                arr[j] = arr[j - gap]
                j -= gap

            arr[j] = temp

        gap //= 2

# 测试排序
arr = [12, 34, 54, 2, 3]
shell_sort(arr)
print("排序后的数组:", arr)
时间复杂度

希尔排序的时间复杂度取决于间隔序列的选择,通常介于 O(n log^2 n) 和 O(n^2) 之间。希尔排序在中等大小的数据集上表现出色,并且比插入排序要快得多。

总之,希尔排序是一种高效的改进的插入排序算法,通过选择不同的间隔序列,逐渐减小子数组的间隔,实现了对数组的排序。了解希尔排序有助于理解排序算法的改进策略,提供了一种高效的排序解决方案。

0 人点赞