Python实现归并排序算法

Python实现归并排序算法

以下是 Python 中的归并排序算法实现示例:

def merge_sort(arr):
    if len(arr) > 1:
        mid = len(arr) // 2  # 计算中间索引
        left_half = arr[:mid]  # 划分左半部分
        right_half = arr[mid:]  # 划分右半部分

        # 递归调用对左右两半进行排序
        merge_sort(left_half)
        merge_sort(right_half)

        # 合并已排序的左右两半
        i = j = k = 0
        while i < len(left_half) and j < len(right_half):
            if left_half[i] < right_half[j]:
                arr[k] = left_half[i]
                i += 1
            else:
                arr[k] = right_half[j]
                j += 1
            k += 1

        # 处理剩余的元素
        while i < len(left_half):
            arr[k] = left_half[i]
            i += 1
            k += 1
        while j < len(right_half):
            arr[k] = right_half[j]
            j += 1
            k += 1

    return arr

# 测试归并排序算法
arr = [12, 11, 13, 5, 6, 7]
print("原始数组:", arr)
sorted_arr = merge_sort(arr)
print("排序后的数组:", sorted_arr)

这段代码定义了一个 merge_sort 函数,该函数使用归并排序算法对输入数组进行排序。您可以通过修改 arr 变量来测试不同的输入数组。

相关推荐
2401_8532757320 分钟前
ArrayList 源码分析
java·开发语言
zyx没烦恼20 分钟前
【STL】set,multiset,map,multimap的介绍以及使用
开发语言·c++
lb363636363620 分钟前
整数储存形式(c基础)
c语言·开发语言
feifeikon22 分钟前
Python Day5 进阶语法(列表表达式/三元/断言/with-as/异常捕获/字符串方法/lambda函数
开发语言·python
大鲤余29 分钟前
Rust,删除cargo安装的可执行文件
开发语言·后端·rust
浪里个浪的102432 分钟前
【C语言】从3x5矩阵计算前三行平均值并扩展到4x5矩阵
c语言·开发语言·矩阵
MoFe138 分钟前
【.net core】【sqlsugar】字符串拼接+内容去重
java·开发语言·.netcore
Envyᥫᩣ1 小时前
深入浅出C#编程语言
开发语言·c#
朱容君1 小时前
Linux系统编程多线程之读写锁讲解
linux·开发语言
杰仔正在努力1 小时前
python成长技能之枚举类
开发语言·python