【C语言】归并排序算法实现

归并排序(Merge Sort)是一种经典的排序算法,由于其采用了分治策略,因此在处理大数据集时表现出了较好的性能。本文将详细介绍归并排序的原理、实现以及优化方法,并以 C 语言为例给出代码实现。

一、归并排序原理

归并排序的核心思想是将待排序的序列分成若干个子序列,每个子序列都是有序的,然后再把有序子序列合并成一个整体有序的序列。具体步骤如下:

  1. 将待排序序列分成若干个子序列,每个子序列只有一个元素,认为这些子序列是有序的。
  2. 将相邻的子序列两两合并,合并过程中保持有序,得到若干个长度为 2 的有序子序列。
  3. 重复步骤 2,直至得到一个长度为 n 的有序序列。

二、归并排序实现

下面给出归并排序的 C 语言实现:

c 复制代码
#include <stdio.h>
#include <stdlib.h>
void Merge(int *arr, int left, int mid, int right) {
    int i, j, k;
    int n1 = mid - left + 1;
    int n2 = right - mid;
    // 创建临时数组
    int L[n1], R[n2];
    // 将原数组元素复制到临时数组中
    for (i = 0; i < n1; i++) {
        L[i] = arr[left + i];
    }
    for (j = 0; j < n2; j++) {
        R[j] = arr[mid + 1 + j];
    }
    // 合并临时数组
    i = 0;
    j = 0;
    k = left;
    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++;
    }
}
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[] = {9, 7, 5, 3, 1, 2, 4, 6, 8};
    int n = sizeof(arr) / sizeof(arr[0]);
    MergeSort(arr, 0, n - 1);
    printf("Sorted array: \n");
    for (int i = 0; i < n; i++) {
        printf("%d ", arr[i]);
    }
    printf("\n");
    return 0;
}

三、归并排序优化

归并排序在处理大数据集时,递归过程可能会导致函数调用栈溢出。为了避免这种情况,可以使用迭代的方式实现归并排序,减少函数调用次数。此外,还可以采用以下优化策略:

  1. 当待排序序列长度较小时,可以采用插入排序代替归并排序。
  2. 在合并过程中,如果左半部分的最大值小于等于右半部分的最小值,则不需要合并。

四、总结

归并排序是一种效率较高的排序算法,时间复杂度为 O( n l o g n nlog_n nlogn),在处理大数据集时表现出了较好的性能。通过采用迭代方式以及优化策略,可以进一步提高归并排序的性能。在实际应用中,归并排序常用于外部排序场景,如磁盘文件排序。

相关推荐
Old Uncle Tom20 小时前
OpenClaw 记忆系统 -- 记忆预加载
java·数据结构·算法·agent
会编程的土豆20 小时前
洛谷题单入门1 顺序结构
数据结构·算法·golang
生信碱移20 小时前
PACells:这个方法可以鉴定疾病/预后相关的重要细胞亚群,作者提供的代码流程可以学习起来了,甚至兼容转录组与 ATAC 两种数据类型!
人工智能·学习·算法·机器学习·数据挖掘·数据分析·r语言
智者知已应修善业21 小时前
【51单片机中的打飞机设计】2023-8-25
c++·经验分享·笔记·算法·51单片机
智者知已应修善业1 天前
【51单片机按键调节占空比3位数码管显示】2023-8-24
c++·经验分享·笔记·算法·51单片机
JasmineX-11 天前
数据结构(笔记)——双向链表
c语言·数据结构·笔记·链表
.5481 天前
## Sorting(排序算法)
python·算法·排序算法
wuweijianlove1 天前
算法的平均复杂度建模与性能回归分析的技术7
算法·数据挖掘·回归
子琦啊1 天前
【算法复习】字符串 | 两个底层直觉,吃透高频题
linux·运维·算法
爱编码的小八嘎1 天前
C语言完美演绎9-7
c语言