Python算法——归并排序

2023-11-30 19:35:16 浏览数 (1)

归并排序(Merge Sort)是一种分治排序算法,它将数组分成两个子数组,分别对子数组进行排序,然后合并两个有序子数组以得到一个有序数组。归并排序是一种高效的排序算法,具有稳定性和适用性广泛的特点。本文将详细介绍归并排序的工作原理和Python实现。

归并排序的工作原理

归并排序的基本思想是将数组不断分成两半,然后递归地对两半进行排序,最后将排序好的两半合并在一起。分治的关键在于如何合并两个有序子数组。归并排序的工作过程如下:

  1. 将数组分成两半,直到每个子数组只包含一个元素。
  2. 递归地将子数组排序。
  3. 合并两个有序子数组,得到一个更大的有序数组。 归并排序的核心思想是不断将问题分解为更小的子问题,然后解决子问题并将它们合并在一起。

下面是一个示例,演示归并排序的过程:

原始数组:[38, 27, 43, 3, 9, 82, 10]

  1. 将数组分成两半:[38, 27, 43] 和 [3, 9, 82, 10]。
  2. 递归地对两个子数组进行排序。
  • 子数组 1:[38, 27, 43],排序后:[27, 38, 43]
  • 子数组 2:[3, 9, 82, 10],排序后:[3, 9, 10, 82]
  1. 合并两个有序子数组,得到排序后的数组:[3, 9, 10, 27, 38, 43, 82]
Python实现归并排序

下面是Python中的归并排序实现:

代码语言:javascript复制
def merge_sort(arr):
    if len(arr) <= 1:
        return arr

    # 分割数组
    mid = len(arr) // 2
    left = arr[:mid]
    right = arr[mid:]

    # 递归排序
    left = merge_sort(left)
    right = merge_sort(right)

    # 合并有序子数组
    return merge(left, right)

def merge(left, right):
    result = []
    i = j = 0

    while i < len(left) and j < len(right):
        if left[i] < right[j]:
            result.append(left[i])
            i  = 1
        else:
            result.append(right[j])
            j  = 1

    result.extend(left[i:])
    result.extend(right[j:])
    return result
  • arr 是待排序的数组。
  • 如果数组长度小于等于 1,则已经有序,直接返回。
  • 分割数组为左右两部分。
  • 递归地对左右两部分进行排序。
  • 合并有序子数组的函数 merge。
示例代码

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

代码语言:javascript复制
def merge_sort(arr):
    if len(arr) <= 1:
        return arr

    mid = len(arr) // 2
    left = arr[:mid]
    right = arr[mid:]

    left = merge_sort(left)
    right = merge_sort(right)

    return merge(left, right)

def merge(left, right):
    result = []
    i = j = 0

    while i < len(left) and j < len(right):
        if left[i] < right[j]:
            result.append(left[i])
            i  = 1
        else:
            result.append(right[j])
            j  = 1

    result.extend(left[i:])
    result.extend(right[j])
    return result

# 测试排序
arr = [38, 27, 43, 3, 9, 82, 10]
sorted_arr = merge_sort(arr)
print("排序后的数组:", sorted_arr)
时间复杂度

归并排序的时间复杂度为 O(n log n),其中 n 是数组的长度。它是一种高效的排序算法,不仅适用于大型数据集,还具有稳定性。

总之,归并排序是一种高效的分治排序算法,通过将数组分成两半,递归地排序子数组,然后合并有序子数组,实现了对数组的归并排序。了解归并排序有助于理解分治算法的思想,并为排序大型数据集提供了一个强大的工具。

0 人点赞