排序算法——归并排序

一、归并排序的概念

归并排序(Merge Sort)是一种分治策略的排序算法,它通过将数组分成两半,递归地对每一半进行排序,然后再将排序好的两半合并成一个有序数组。归并排序的时间复杂度在最好、平均和最坏情况下均为O(n log n),并且是稳定的排序算法。

二、归并排序的原理

1. 分解:将数组分成两半,递归地对每一半进行排序。

2. 合并:将排序好的两个子数组合并成一个有序数组。

三、代码分析:

逻辑步骤:

1. 分解:如果数组的长度大于1,则将数组分成两个相等长度的子数组。

2. 递归排序:递归地对每个子数组进行归并排序。

3. 合并:将两个已排序的子数组合并成一个有序数组。

cpp 复制代码
#include <stdio.h>
void print(int *arr, int size)
{
    for (int i = 0; i < size; i++)
    {
        printf("%d ", arr[i]);
    }
    printf("\n");
}
/*merge将数组分成两组,并对两组数组进行合并(按大小顺序)*/
void merge(int *arr, int left, int mid, int right)
{
    int n1 = mid - left + 1;
    int n2 = right - mid;
    /*创建临时数组*/
    int L[n1], R[n2];

    /*复制数据到临时数组*/
    for (int i = 0; i < n1; i++)
    {
        L[i] = arr[i + left];
    }
    for (int j = 0; j < n2; j++)
    {
        R[j] = arr[j + mid + 1];
    }

    /*合并临时数组回原数组*/
    int i = 0;// 初始索引 of 第一个子数组
    int j = 0;// 初始索引 of 第二个子数组
    int k = left;// 初始索引 of 合并后的子数组
    while(i < n1 && j < n2)
    {
        if(L[i] <= R[j])
        {
            arr[k] = L[i];
            i++;
        }
        else{
            arr[k] = R[j];
            j++;
        }
        k++;
    }

    while(i < n1)
    {
        arr[k] = L[i];
        i++;
        k++;
    }

    while(j < n2)
    {
        arr[k] = R[j];
        j++;
        k++;
    }

}

/*mergeSort:该函数用于递归地对数组进行排序。*/
void mergeSort(int *arr, int left, int right)
{
    if (left < right)
    {
        int mid = left + (right - left) / 2;
        /*递归地排序两个数组*/
        mergeSort(arr, left, mid);
        mergeSort(arr, mid + 1, right);
        /*合并两个数组*/
        merge(arr, left, mid, right);
    }
}

int main()
{
    int arr[] = {5, 4, 6, 2, 1, 3, 0};
    int size = sizeof(arr) / sizeof(int);
    printf("归并排序前的数组元素如下:");
    print(arr,size);
    printf("归并排序后的数组元素如下:");
    mergeSort(arr, 0, size - 1);
    print(arr,size);
    return 0;
}

运行结果:

四、复杂度分析

1、时间复杂度

最好情况、平均情况和最坏情况:时间复杂度均为O(n log n)。

2、空间复杂度

空间复杂度:O(n)

因为归并排序需要额外的空间来存储临时数组。归并排序是一种高效的排序算法,尤其适用于大数据集。它不仅稳定,而且在各种情况下都能保持较好的性能。

相关推荐
智驱力人工智能2 分钟前
小区高空抛物AI实时预警方案 筑牢社区头顶安全的实践 高空抛物检测 高空抛物监控安装教程 高空抛物误报率优化方案 高空抛物监控案例分享
人工智能·深度学习·opencv·算法·安全·yolo·边缘计算
孞㐑¥44 分钟前
算法——BFS
开发语言·c++·经验分享·笔记·算法
月挽清风1 小时前
代码随想录第十五天
数据结构·算法·leetcode
XX風1 小时前
8.1 PFH&&FPFH
图像处理·算法
NEXT061 小时前
前端算法:从 O(n²) 到 O(n),列表转树的极致优化
前端·数据结构·算法
代码游侠2 小时前
学习笔记——设备树基础
linux·运维·开发语言·单片机·算法
想进个大厂2 小时前
代码随想录day37动态规划part05
算法
sali-tec2 小时前
C# 基于OpenCv的视觉工作流-章22-Harris角点
图像处理·人工智能·opencv·算法·计算机视觉
子春一2 小时前
Flutter for OpenHarmony:构建一个 Flutter 四色猜谜游戏,深入解析密码逻辑、反馈算法与经典益智游戏重构
算法·flutter·游戏
人道领域3 小时前
AI抢人大战:谁在收割你的红包
大数据·人工智能·算法