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 变量来测试不同的输入数组。

相关推荐
程序员小寒1 分钟前
JavaScript设计模式(四):发布-订阅模式实现与应用
开发语言·前端·javascript·设计模式
csbysj20202 分钟前
JSON 语法
开发语言
郝学胜-神的一滴5 分钟前
深入解析:生成器在UserList中的应用与Python可迭代对象实现原理
开发语言·python·程序人生·算法
为美好的生活献上中指5 分钟前
*Java 沉淀重走长征路*之——《Linux 从入门到企业实战:一套六步法,带你打通运维与开发的任督二脉》
java·linux·运维·开发语言·阿里云·华为云·linux命令
wuqingshun3141599 分钟前
依赖注入的方式有几种,各是什么?
java·开发语言
李昊哲小课23 分钟前
aiomysql 完整实战教程
python·mysql·pymysql·aiomysql
JosieBook26 分钟前
【C#】C# 中的 enum、struct 和 class 对比总结
开发语言·算法·c#
cui_ruicheng26 分钟前
C++ 新特性(下):可变参数模板与 STL 扩展机制
开发语言·c++·c++11
m0_7269659830 分钟前
面面面(2)
java·开发语言
Csvn33 分钟前
描述符协议与动态属性管理
python