考研数据结构——C语言实现归并排序

  1. 包含头文件 :程序首先包含了标准输入输出库stdio.h,以便使用printf等函数进行输入输出操作。

  2. 定义数组和数组大小 :定义了一个宏N,其值为5,表示数组q的长度。数组q被初始化为{5, 3, 8, 4, 2},这是我们要排序的原始数组。同时定义了一个辅助数组w,用于在归并过程中临时存储数据。

  3. 归并排序函数merge_sort函数是一个递归函数,它接受两个参数lr,分别表示要排序的子数组的起始和结束索引。如果子数组的长度为1(即l >= r),则不需要排序,函数直接返回。函数递归地将数组分为两半,分别对左半部分lmid和右半部分mid + 1r进行排序。

    在归并过程中,使用三个指针ijk,分别指向左半部分的当前元素、右半部分的当前元素和辅助数组w的当前位置。第一个while循环比较左右两部分的当前元素,将较小的元素复制到辅助数组w中。接下来的两个while循环分别处理左右两部分的剩余元素。最后一个for循环将辅助数组w中的元素复制回原数组q,完成归并过程。

  4. 主函数main函数是程序的入口点。调用merge_sort函数,传入0和N - 1作为参数,表示对整个数组q进行排序。使用一个for循环和printf函数打印排序后的数组。

  5. 运行结果 :程序将输出排序后的数组{2, 3, 4, 5, 8},这表示数组q已经被成功排序。

  6. 总结:这个程序展示了归并排序算法的实现,它通过递归地将数组分成更小的部分,然后合并这些部分来排序整个数组。归并排序的时间复杂度为O(n log n),是一种稳定的排序算法。

cpp 复制代码
#include <stdio.h>

#define N 5 // 定义数组q的长度

int q[N] = { 5, 3, 8, 4, 2 }; // 待排序的数组
int w[N]; // 辅助数组

void merge_sort(int l, int r) {
    if (l >= r)
        return;
    int mid = l + r >> 1; // 计算中间位置
    merge_sort(l, mid);
    merge_sort(mid + 1, r);
    int i = l, j = mid + 1, k = 0;
    while (i <= mid && j <= r) {
        if (q[i] <= q[j])
            w[k++] = q[i++];
        else
            w[k++] = q[j++];
    }
    while (i <= mid)
        w[k++] = q[i++];
    while (j <= r)
        w[k++] = q[j++];
    for (i = l, j = 0; j < k; i++, j++)
        q[i] = w[j];
}

int main() {
    merge_sort(0, N - 1);

    printf("Sorted array: ");
    for (int i = 0; i < N; i++) {
        printf("%d ", q[i]);
    }
    printf("\n");
    return 0;
}
相关推荐
夏乌_Wx5 分钟前
反转链表:三种实现思路与细节梳理
数据结构·链表
Once_day9 分钟前
C++之《程序员自我修养》读书总结(4)
c语言·c++·编译和链接
三无少女指南1 小时前
开发者环境配置:用 Ollama 实现本地大模型部署(附下载慢的解决方案
c语言·开发语言·数据库·ubuntu
紫陌涵光1 小时前
108.将有序数组转换为二叉搜索树
数据结构·算法·leetcode
2501_918126911 小时前
stm32核心板是什么属性?
linux·c语言·stm32·嵌入式硬件·个人开发
m0_531237171 小时前
C语言-操作符练习
c语言·开发语言
载数而行5202 小时前
算法系列2之最短路径
c语言·数据结构·c++·算法·贪心算法
fu的博客2 小时前
【数据结构10】满/完全二叉树、顺序/链式存储
数据结构·
代码改善世界3 小时前
栈和队列的实现与详解(C语言版):从底层原理到代码实战
c语言·开发语言
逆境不可逃3 小时前
【除夕篇】LeetCode 热题 100 之 189.轮转数组
java·数据结构·算法·链表