Python算法——归并排序

举报
Echo_Wish 发表于 2023/11/04 14:11:26 2023/11/04
【摘要】 归并排序(Merge Sort)是一种分治排序算法,它将数组分成两个子数组,分别对子数组进行排序,然后合并两个有序子数组以得到一个有序数组。归并排序是一种高效的排序算法,具有稳定性和适用性广泛的特点。本文将详细介绍归并排序的工作原理和Python实现。 归并排序的工作原理归并排序的基本思想是将数组不断分成两半,然后递归地对两半进行排序,最后将排序好的两半合并在一起。分治的关键在于如何合并两个...

归并排序(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中的归并排序实现:

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进行归并排序的示例代码:

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 是数组的长度。它是一种高效的排序算法,不仅适用于大型数据集,还具有稳定性。

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

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。