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

相关推荐
木头左3 分钟前
年化波动率匹配原则在ETF网格区间选择中的应用
python
清空mega7 分钟前
从零开始搭建 flask 博客实验(3)
后端·python·flask
音符犹如代码16 分钟前
Java并发List实战:CopyOnWriteArrayList原理与ArrayList常见面试题
java·开发语言·面试·list
又是忙碌的一天27 分钟前
抽象类和接口
java·开发语言
亮剑201829 分钟前
第2节:程序逻辑与控制流——让程序“思考”
开发语言·c++·人工智能
lly20240633 分钟前
Go 语言接口
开发语言
霜绛33 分钟前
C#知识补充(二)——命名空间、泛型、委托和事件
开发语言·学习·unity·c#
程序员小远35 分钟前
7个常见的Jmeter压测问题
自动化测试·软件测试·python·测试工具·测试用例·压力测试·性能测试
红尘炼丹客43 分钟前
《DeepSeek-OCR: Contexts Optical Compression》速览
人工智能·python·自然语言处理·ocr
Dxxyyyy1 小时前
零基础学JAVA--Day26(枚举类)
java·开发语言